NAVAL  POSTGRADUATE  SCHOOL 
Monterey,  California 


THESIS 

CLASSIFICATION,  SEARCH,  AND  RETRIEVAL  IN  A 
MULTI-VARIABLE,  MULTI-LEVEL  TAXONOMY: 
APPLICATION  TO  DECISIONNET 

by 

Christopher  M.  Corgnati 
September,  1997 

Thesis  Advisor:  Hemant  K.  Bhargava 


Approved  for  public  release;  distribution  is  unlimited. 


REPORT  DOCUMENTATION  PAGE 


Form  Approved 
OMB  No .  0704-0188 


Public  reporting  burden  for  this  collection  of  information  is  estimated  to  average  1  hour  per  response,  including  the  time  for  reviewing  instruction,  searching 
existing  data  sources,  gathering  and  maintaining  the  data  needed,  and  completing  and  reviewing  the  collection  of  information.  Send  comments  regarding  this 
burden  estimate  or  any  other  aspect  of  this  collection  of  information,  including  suggestions  for  reducing  this  burden,  to  Washington  headquarters  Services, 
Directorate  for  Information  Operations  and  Reports,  1215  Jefferson  Davis  Highway,  Suite  1204,  Arlington,  VA  22202-4302,  and  to  the  Office  of  Management  and 
Budget,  Paperwork  Reduction  Project  (0704-0188)  Washington  DC  20503. 


1.  AGENCY  USE  ONLY  (Leave  blank) 


2.  REPORT  DATE 
September  1997 


3.  REPORT  TYPE  AND  DATES  COVERED 
Master’s  Thesis 


4.  TITLE  AND  SUBTITLE  :  CLASSIFICATION,  SEARCH,  AND  RETRIEVAL  IN  A  MULTI-VARIABLE  , 
MULTI-LEVEL  TAXONOMY:  APPLICATION  TO  DECISIONNET 


6.  AUTHOR(S) 

Corgnati,  Christopher  M. 


7.  PERFORMING  ORGANIZATION  NAME(S)  AND  ADDRESS(ES) 
Naval  Postgraduate  School 
Monterey,  CA  93943-5000 


9.  SPONSORING  /  MONITORING  AGENCY  NAME(S)  AND  ADDRESS (ES) 


5.  FUNDING  NUMBERS 


8.  PERFORMING 
ORGANIZATION  REPORT 
NUMBER 


10.  SPONSORING/ 
MONITORING 

AGENCY  REPORT  NUMBER 


11.  SUPPLEMENTARY  NOTES 

The  views  expressed  in  this  thesis  are  those  of  the  author  and  do  not  reflect  the  official  policy  or  position  of  the  Department  of 
Defense  or  the  U.S.  Government. 


12a.  DISTRIBUTION  /  AVAILABILITY  STATEMENT  12b.  DISTRIBUTION  CODE 

Approved  for  public  release;  distribution  unlimited. 


13.  ABSTRACT  (maximum  200  words) 

The  explosion  of  information  available  on  global  computer  networks  underlines  the  need  for  effective  repositories  that  facilitate 
organization  of,  and  search  for,  information.  These  digital  repositories  may  contain  simple  data,  or  increasingly,  objects  of  other 
types  such  as  software  and  decision  models.  A  taxonomy  can  be  thought  of  as  a  navigational  aid  to  a  repository.  Organization  of 
objects  may  take  place  along  multiple  dimensions,  each  of  which  may  have  a  taxonomy  of  classification  terms  that  spans  many 
levels. 

This  thesis  examines  the  design  and  development  of  a  WWW  based  Classification,  Registration,  Search,  and  Retrieval  System.  The 
system  was  applied  and  tested  on  the  DecisionNet  project  which  is  an  electronic  brokerage  house  for  decision  technologies.  In 
order  to  facilitate  user  interaction  via  the  WWW  the  system  was  designed  to  be  run  through  a  standard  web  browser.  A  graphical 
user  interface  was  developed  in  Java.  The  back-end  functions  for  data  management,  search  and  retrieval  were  also  programmed 
largely  in  Java. 


14.  SUBJECT  TERMS  NUMBER  OF 

Taxonomy,  Repository,  Information  Search  and  Retrieval,  Java  Applet,  DecisionNet,  Decision  Support  pages 

Systems  168 


17.  SECURITY  CLASSIFICATION 

OF  REPORT 

Unclassified 


18.  SECURITY  CLASSIFICATION  OF 

THIS  PAGE 

Unclassified 


19.  SECURITY  CLASSIFI-  CATION 

OF  ABSTRACT 

Unclassified 


16.  PRICE  CODE 


20.  LIMITATION 
OF  ABSTRACT 


1 


Approved  for  public  release;  distribution  is  unlimited. 


CLASSIFICATION,  SEARCH,  AND  RETRIEVAL  IN  A 
MULTI- VARIABLE,  MULTI-LEVEL  TAXONOMY: 
APPLICATION  TO  DECISIONNET 

Christopher  M.  Corgnati 
Lieutenant,  United  States  Navy 
B.S.,  Villanova  University,  1990 


Submitted  in  partial  fulfillment  of  the 
requirements  for  the  degree  of 

MASTER  OF  SCIENCE  IN  INFORMATION  TECHNOLOGY 

MANAGEMENT 

from  the 

NAVAL  POSTGRADUATE  SCHOOL 
September  1997 


Author: 


Approved  by 


Management 

iii 


ABSTRACT 


The  explosion  of  information  available  on  global  computer  networks  underlines 
the  need  for  effective  repositories  that  facilitate  organization  of,  and  search  for,  infor¬ 
mation.  These  digital  repositories  may  contain  simple  data,  or  increasingly,  objects 
of  other  types  such  as  software  and  decision  models.  A  taxonomy  can  be  thought  of 
as  a  navigational  aid  to  a  repository.  Organization  of  objects  may  take  place  along 
multiple  dimensions,  each  of  which  may  have  a  taxonomy  of  classification  terms  that 
spans  many  levels. 

This  thesis  examines  the  design  and  development  of  a  WWW  based  Classifica¬ 
tion,  Registration,  Search,  and  Retrieval  System.  The  system  was  applied  and  tested 
on  the  DecisionNet  project  which  is  an  electronic  brokerage  house  for  decision  tech¬ 
nologies.  In  order  to  facilitate  user  interaction  via  the  WWW  the  system  was  designed 
to  be  run  through  a  standard  web  browser.  A  graphical  user  interface  was  developed 
in  Java.  The  back-end  functions  for  data  management,  search  and  retrieval  were  also 
programmed  largely  in  Java. 
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I. 


INTRODUCTION 


A  large  number  of  World  Wide  Web  (WWW)  applications  can  be  interpreted 
as  providing  access  to  a  collection  of  digital  resources  such  as  information  (e.g.,  The 
Library  of  Congress  [Ref.  1]),  or  software  code  (e.g.,  The  Java  Repository  [Ref.  2]),  or 
mathematical  decision  models  (e.g.,  DecisionNet  [Ref.  3]).  Collections  or  repositories, 
in  the  classical  library  science  approach,  are  subject  to  operations  such  as  classification 
and  indexing,  and  search  and  retrieval.  However,  these  operations  are  only  weakly, 
if  at  all,  supported  in  most  Web-based  repositories,  leading  to  difficulties  in  locating 
suitable  objects  from  large  collections.  For  example,  a  search  conducted  using  general 
search  engines  such  as  Excite  [Ref.  4]  or  Lycos  [Ref.  5]  results  in  thousands  of  “hits” 
only  a  few  of  which  may  actually  be  relevant. 

This  thesis  describes  a  system  for  classifying,  registering,  searching,  and  re¬ 
trieving  objects  in  a  Web-based  digital  library,  in  a  way  that  these  functions  can  be 
accessed  by  users  via  their  Web  browsers.  This  work  is  done  in  the  specific  context 
of  DecisionNet  [Ref.  6],  a  digital  library  of  decision  technologies.  However,  in  its 
architecture  and  design  as  well  as  in  its  implementation,  the  system  is  general  enough 
to  be  immediately  useful  for  classification  and  search  in  other  repositories.  Since  the 
classification  of  objects  in  DecisionNet  is  done  with  multiple  attributes,  each  of  which 
has  several  levels,  a  Web-based  user  interface  for  access  to  classification  and  search 
functions  poses  significant  challenges.  Hence,  much  of  the  system  and  this  thesis  is  fo¬ 
cused  on  the  development  of  a  general,  Web-based,  user  interface  for  a  multi- variable, 
multi-dimensional  classification  of  a  repository  of  objects. 

A.  THE  DECISIONNET  CONCEPT 

DecisionNet  is  a  framework  for  brokering  the  use  of  decision  support  technolo¬ 
gies.  Earley  [Ref.  7]  described  DecisionNet  in  the  following  terms: 


1 


The  main  premise  of  DecisionNet  is  that  consumers  should  be  able  to  utilize 
decision  support  technologies  as  services  over  the  World  Wide  Web  (WWW), 
instead  of  purchasing  them  as  stand-alone  products.  By  providing  decision 
support  technologies  over  the  WWW  (either  for  free  of  for  a  nominal  usage 
fee),  users  would  be  able  to  tap  into  the  power  of  such  technologies  without 
the  normally  prohibitive  costs  involved  with  purchasing  or  downloading  and 
installing  a  specific  product.  The  DecisionNet  prototype  serves  as  an  interface 
between  consumers  and  providers  of  decision  support  software,  so  that  interac¬ 
tions  with  multiple  technologies  may  take  place  at  one  convenient  location.  In 
this  sense,  DecisionNet  performs  the  role  of  an  agent,  facilitating  transactions 
between  consumers  and  providers  of  decision  support  technologies. 

With  that  as  a  foundation  we  will  explore  the  genesis  of  this  thesis. 

B.  IMPROVING  DECISIONNET 

The  need  for  an  improved  search  engine  in  DecisionNet  was  first  identified 
by  Rogers.  [Ref.  8]  It  stated,  ”  Further  research  is  needed  on  the  second  part,  to 
develop  intelligent  search  and  retrieval  algorithms.”  The  search  and  retrieval  problem 
continued  and  was  further  identified  by  Earley.  [Ref.  7]  It  stated: 

The  indexed  search  script  developed  in  this  thesis  assumes  that  the  consumer 
is  looking  for  exact  matches  to  his  query.  However,  there  may  be  some  tech¬ 
nologies  that  are  closely  related  to  a  consumer’s  query  without  being  an  exact 
match.  The  taxonomy  for  indexing  technologies  is  already  in  place  and  func¬ 
tional.  (Rogers,  1996)  A  method  for  assigning  ’scores’  based  on  a  consumer’s 
request  would  prove  to  be  beneficial. 

As  the  size  of  an  object  library  grows,  so  will  the  diversity  of  the  objects  in 
that  library.  The  taxonomy  needed  to  accurately  classify  these  diverse  objects  will 
also  grow.  A  taxonomy  is  a  shared  set  of  terms  that  are  relevant  to  the  domain  of 
knowledge  that  the  objects  are  a  part  of.  As  the  taxonomy  and  number  of  search 
criteria  grow,  the  likelihood  of  finding  exact  matches  drops  very  quickly.  This  is  true 
of  DecisionNet,  which  contains  relatively  few  objects.  These  observations  provide  the 
basis  for  this  thesis. 
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C.  PROBLEM  DEFINITION 

Information  retrieval  on  the  WWW  is  both  an  art  and  a  science.  Keyword 
based  searches  may  retrieve  nothing  or  several  million  hits.  The  art  is  knowing  what  to 
search  for.  WWW  search  engines,  even  the  ’’advanced”  search  engines,  are  notoriously 
inaccurate  (commit  both  Type  1  errors  and  plenty  of  Type  2  errors).  A  Type  1  error 
occurs  when  a  relevant  result  is  ignored.  A  Type  2  error  occurs  when  an  irrelevant 
result  is  returned.  A  search  for  Apple  Computers  returns  58,312  hits  or  possible 
items  of  interest.  Of  those,  approximately  320  are  closely  tied  to  the  corporation  in 
question.  The  remaining  sites  have  little  to  no  relevance  to  Apple  Computers  Inc. 
This  example  uses  WWW  sites,  but  the  same  idea  applies  in  general  to  any  ’object’. 
The  challenge  is  to  rank  various  objects  giving  the  user  the  most  relevant  results. 
What  is  a  good  measure  of  relevance?  Is  number  of  occurrences  of  a  word  or  the 
semantic  distance  between  desired  and  available  terms  appropriate? 

Reasons  for  the  inaccuracy  of  searches  include: 

•  The  lack  of  common  semantics  between  multiple  sites,  providers  of  objects, 
and  users  of  objects 

•  Inexact  classification,  if  any,  of  objects  using  the  semantics  that  do  exist 

•  Lack  of  reliable  methods  to  compute  relevance  of  objects  that  only  satisfy  some 
of  the  attributes  that  a  user  is  looking  for 

The  purpose  of  taxonomies  is  to  develop  a  shared  understanding  of  lists  of  terms, 
and  relationships  between  these  terms,  encountered  in  work  in  some  domain.  Once 
there  is  a  taxonomy,  the  search  engine  can  make  use  of  the  shared  vocabulary  as  well 
as  exploit  the  relationships  between  terms  in  order  to  create  meaningful  relevance 
scores.  A  taxonomy  may  be  multi-dimensional,  which  means  that  each  object  must 
be  described  using  more  than  one  collections  of  class  terms. 

A  taxonomy-based  organization  and  search  system  would  facilitate  working 
with  taxonomies,  including  creating  and  maintaining  the  classification  terms,  classi¬ 
fying  objects,  and  conducting  searches.  It  would  include  a  taxonomy  browser,  taxon- 
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omy  editor,  taxonomy-based  search  engine,  an  editor  for  search  criteria  specification, 
search  algorithm,  search  algorithm  parameters  editor,  and  a  results  visualizer. 

However,  taxonomies — and  the  accompanying  relationships — can  be  fairly  com¬ 
plex.  For  example,  in  multi-level  taxonomies,  two  terms  may  be  related  but  it  may 
require  several  steps  to  make  the  deduction  that  they  are.  In  multi-dimensional  tax¬ 
onomies,  multiple  independent  collections  of  terms  may  be  required  to  classify  the 
objects,  each  collection  comprising  a  taxonomy.  Developing  the  various  components 
of  a  taxonomic  system  gets  more  complex  when  the  taxonomy  is  dynamic,  multi- 
variable,  and  multi-dimensional;  it  becomes  particularly  challenging  in  the  context  of 
developing  Web-based  taxonomic  systems. 

In  this  thesis,  we  give  a  formal  logic-based  specification  of  a  taxonomy-based 
organization  and  search  service.  We  focus  on  a  particular  kind  of  taxonomic  system, 
where  the  taxonomy  is  restricted  to  a  hierarchical  arrangement  of  terms  (with  single¬ 
inheritance)  but  one  which  may  consist  of  multiple  independent  taxonomies.  The 
multi-taxonomy  aspect  of  such  systems  complicates  the  design  of  its  different  compo¬ 
nents,  including  the  browser,  editor  and  the  search  and  retrieval  methods.  Multiple 
inheritance  would  make  things  further  complex,  but  we  think  our  approach  would 
generalize  and  scale  up  to  that  scenario  as  well. 

Our  interest  in  this  area  grew  out  of  work  on  designing  DecisionNet,  a  digital 
library  of  decision  technologies.  DecisionNet,  as  described  in  Section  A,  is  currently 
implemented  through  common  gateway  interface  (CGI)  scripts.  This  implementation 
limits  it  to  a  single  taxonometric  dimension.  The  introduction  of  Java  applets  allows 
users  to  view  and  utilize  the  entire  four  level  taxonomy.  [Ref.  8] 

D.  OUTLINE  FOR  REMAINDER  OF  THESIS 

Chapter  II  discusses  the  taxonomy  and  defines  relationships  within  it.  Chap¬ 
ter  III  explores  the  challenges  of  searching  and  retrieving  multi- variable,  multi¬ 
dimensional  objects.  Chapter  IV  provides  the  analysis  and  design  of  the  goal  ar- 
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chitecture.  Chapter  V  represents  the  actual  implementation  and  the  rationale  for 
deviations  from  the  goal  architecture.  Chapter  VI  is  a  tour  of  the  system.  Finally, 
Chapter  VII  identifies  the  difficulties  and  challenges  that  were  overcome  and  those 
that  remain. 
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II.  TAXONOMY 


A.  TAXONOMY:  FORMAL  SPECIFICATION 

Definition  1  (Taxonomy)  A  taxonomy  is  a  collection  T  of  class  terms  used  in  clas¬ 
sifying  or  describing  a  library  of  objects  A  in  some  domain.  The  classification  is 
achieved  via  instances  ^(r,  A)  of  mapping  relationships  T.  Additionally,  there  may 
be  instances  u;(r,  T)  of  structural  relationships  ft  involving  the  elements  ofT,  and  a 
collection  of  logical  axioms  $  constraining  these  relationships.  To  be  precise,  each 
element  in  W  is  a  relationship  that  maps  elements  of  A  onto  elements  of  T,  and  each 
element  in  ft  is  relationship  from  the  set  T  onto  itself 

Formally,  we  write  a  taxonomy  scheme  as  a  tuple 


<  ft,#,'!'  > 

and  a  taxonomy  instance  as  a  tuple 


ail) 


<i>(r,r),4>,A,<«r,A)>  (11.2) 

In  this  thesis,  as  mentioned  above,  our  interest  is  in  a  special  kind  of  taxonomic 
system.  This  system  is  defined  by  specifying  the  structure  of  ft,  $  and  T.  For  the 
purpose  of  specifying  the  denotational  semantics  of  the  relationships,  let  A  denote  the 
universe  of  discourse  (i.e.,  each  object  in  A  maps  to  an  element  of  A)  corresponding 
to  the  object  collection  A  that  needs  to  be  classified  and  searched.  Further,  for  any 
class  term  7  (G  T),  let  A7  denote  the  objects  (subset  of  A)  belonging  to  class  7. 

1.  Relationships 

We  include  the  following  relationships  in  our  taxonomic  system. 

a.  ft 

Taxonomy  specification  involves  two  relationships:  refines  and  syn. 

•  refines:  a  binary  relationship  of  the  form  71  refines  72,  where  71,72  G  T.  The 
informal  interpretation  is  that  all  objects  in  the  class  71  also  belong  to  class 
72.  Formally,  we  get 
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V7i,72  (7i  refines  72)  -4  (A7l  C  A72)  (II.3) 

•  syn:  a  binary  relationship  of  the  form  syn(7i,72),  where  71,72  G  T.  The 
informal  interpretation  is  that  classes  71  and  72  are  synonyms.  Formally,  the 
semantics  are  given  as: 


(syn (71, 72))  -»  (A71  =  A72)  (II.4) 

Sometimes,  synonyms  may  be  used  to  force  a  hierarchical  representation  for  a 
collection  of  terms  and  relationships  that  would  otherwise  require  a  network 
(multiple  parents  allowed).  This  is  achieved  by  making  a  copy — synonym — of 
an  object  at  multiple  branches  in  the  taxonomy  tree. 

In  addition,  we  make  use  of  a  relationship  isA  (of  the  form  71  isA  72) 
which  is  derived  from  the  relationship  refines,  except  that  is  A  is  transitive  (a  complete 
definition  is  given  via  axioms  II.8  and  II.9).  This  relationship,  strictly,  is  not  required, 
but  is  included  as  syntactic  sugar  and  for  ease  of  exposition. 

Finally,  note  that  we  can  define  a  relationship  parent  which  is  the 
inverse  of  the  isA  (or  child)  relationship,  and  relationships  ancestor  and  descen¬ 
dant  that  are  transitive  relationships  based  on  the  parent  and  child  relationships, 
respectively. 

b.  vp 

Object  classification  involves  just  one  relationship  ins-of. 

•  ins-of:  a  binary  relationship  of  the  form  A  ins-of  7,  where  A  E  A  and  7  G  T. 
The  interpretation  is  that  object  A  in  the  domain  belongs  to  the  class  7  in  the 
taxonomy.  Formally,  we  say 

(A  ins-of  7)  — *•  (A  e  A7)  (II.5) 

As  above,  we  also  allow  a  binary  relationship  sib  (of  the  form  sib(Ai,  A2), 
derived  from  the  relationship  ins-of,  to  indicate  that  Aj  and  A2  are  siblings  (have  the 
same  parent);  Axiom  11.14  further  clarifies  the  meaning  of  this  relationship.  This 
relationship,  strictly,  is  also  not  required,  but  is  included  for  clarity. 
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2.  Axioms,  $ 

The  formal  semantics  of,  and  integrity  constraints  on,  the  relationships  stated 
above  can  be  stated  clearly  via  the  following  axioms. 

refines:  subclass  hierarchy,  single-parent  hierarchy  All  objects  that  are 
an  instance  of  a  certain  class  are  also  instances  of  its  parent  class.  Second, 
each  term  in  T  can  be  a  refinement  of  at  most  one  (parent)  term.  The  root 
term  has  no  parent. 


((A  ins-of  71)  A  (71  refines  72))  — ►  (A  ins-of  72)  (II. 6) 

((71  refines  72)  A  (7!  refines  73))  — ►  (72  =  73)  (H.7) 

isA:  refines,  transitive 

(71  refines  72)  — ►  (71  isA  72)  (II.8) 

((71  isA  72)  A  (72  isA  73))  ->  (71  isA  73)  (II.9) 

In  terms  of  the  universe  of  discourse, 

(71  isA  72)  <-*■  (A71  C  A72)  (11.10) 

synonym:  equivalence  relation 

syn(7i,7i)  (11*11) 

syn(7i,72)  -*•  syn(72,7i)  (11.12) 

(syn(7i,  72)  A  syn(72, 73))  ->  syn(7i,73)  (11.13) 

sibling 

((Aj  ins-of  7)  A  (A2  ins-of  7))  *->  sib(Ai,  A2)  (11.14) 

3.  Multi-Dimensional  Taxonomic  System 

A  multi-dimensional  taxonomic  classification  system  is  one  in  which  a  collec¬ 
tion  of  objects  A  must  be  classified  along  more  than  one  dimension,  and  where  there  is 
an  independent  taxonomy  on  each  dimension.  In  an  n-dimensional  taxonomic  system, 
let  us  denote  the  collection  of  terms  in  the  taxonomies  by  T1 . . .  Tn.  If  we  assume 
that  all  dimensions  are  governed  by  the  same  relationship  schemes  (fi,  <3>)  and  axioms 
(T),  then  a  multidimensional  taxonomic  scheme  can  be  written  as  the  tuple 
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<  0,$,  ^  > 


(H.15) 


and  a  taxonomy  instance  as  a  tuple 


<  (r\  •  •  ■ .  I”),  Mr1,  r‘) . w(p\  r»,  #,  a,  «.(r\  A), ....  ^(r,  A)  >  (me) 


which  may,  alternately,  be  written  as  a  collection  of  tuples: 


<  r1,  c^(rx,  r1),  a,  -^(r1,  a)  >,...,<rv(r^n),$,A,^(rn,A)  >  (11.17) 

B.  TAXONOMY  DEVELOPMENT  AND  OBJECT  CLAS¬ 
SIFICATION 

1.  Taxonomy  Development 

For  a  single  taxonomy,  this  means  specifying 

•  elements  of  F 

•  instances  of  the  relationships  in  (i.e. ,  instances  of  refines  and  syn). 

For  example,  consider  the  “problem  type”  taxonomy  tree  from  the  GAMS 
system,  [Ref.  9]  displayed  in  Figure  1.  Elements  of  T  are  all  the  terms  appearing  in 
the  list.  The  subclass  relationships  are  represented  using  the  refines  relationship,  e.g. 
(using  the  shorthand  codes  from  the  taxonomy), 

ref ines(Gl,G) 

ref ines(G2,G) 
ref ines(G2a,G2) 
ref ines(G2b,G2) 
ref ines(G2b,G2) 
refines (G2cl , G2c) 
refines (G2c2 , G2c) 
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[F]  Solution  of  nonlinear  equations 

[G]  Optimization  (search  also  classes  K,  L8) 

[Gl]  Unconstrained 

[G2]  Constrained 

[G2a]  Linear  programming 

[G2b]  Transportation  and  assignments  problem 
[G2c]  Integer  programming 
[G2cl]  Zero/one 

[G2c2]  Covering  and  packing  problems 
[G2c3]  Knapsack  problems 
[G2c4]  Matching  problems 
[G2c5]  Routing,  scheduling,  location  problems 
[G2c6]  Pure  integer  programming 
[G2c7]  Mixed  integer  programming 
[G2d]  Network  (for  network  reliability  search  class  M) 
[G2e]  Quadratic  programming 
[G2f]  Geometric  programming 
[G2g]  Dynamic  programming 
[G2h]  General  nonlinear  programming 
[G2i]  Global  solution  to  nonconvex  problems 
[G3]  Optimal  control 
[G4]  Service  routine 

[H]  Differentiation,  integration 

[I]  Differential  and  integral  equations 

[J]  Integral  transforms 

[K]  Approximation  (search  also  class  L8) 

Figure  1.  Fragment  of  “problem  type”  taxonomy  from  GAMS  system 


For  an  n-dimensional  taxonomy,  this  process  must  be  repeated  for  each  of  the 
n  dimensions. 

Note  also  that  there  is  an  obvious  database  implementation  of  a  taxonomy  in 
terms  of  these  two  relations. 

2.  Object  Classification 

Classification  of  objects  Ac  A  involves  specifying  instances  of  the  relationships 
in  i.e.,  one  instance  of  the  ins-of  relationship  for  each  A  G  A. 
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Modules  for  class  G2cl 
Package  NAG  at  GRANTA 

•  H02BBE  Solves  zero-one,  general,  mixed,  or  all  (pure)  integer  programming 
problems  using  ... 

•  H02BBF  Solves  zero-one,  general,  mixed,  or  all  (pure)  integer  programming 
problems  using  ... 

Figure  2.  Fragment  of  object  classification  in  GAMS  taxonomy 


which  would  be  represented  as 

ins-of (G2cl,H02BBE) 
ins-of (G2cl,H02BBF) 
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III.  SEARCH  AND  RETRIEVAL  IN  A 
TAXONOMIC  SYSTEM 

Assume  that  an  object  receives  a  score  of  1  if  it  matches  exactly  the  search 
criteria  specified  by  the  user,  and  a  score  of  0  when  it  has  no  relevance  to  the  user’s 
requirements. 

A.  SEARCH  CRITERIA  SPECIFICATION 

Let  k  denote  the  criteria  for  searching  and  determining  relevance  of  objects  in 
a  taxonomy.  For  a  single-dimensional  taxonomy,  k  simply  specifies  a  class  7  G  T.  If 
we  denote  the  dimension  by  S,  then  k  may  be  written  as 

6  =  7  (III.l) 

which  specifies  a  search  for  objects  that  belong  to,  or  otherwise  are  relevant 
to,  class  7.  For  a  multi-dimensional  taxonomy  with  dimensions  61,  ...,5n,  we  write 
the  criteria  k,  for  dimension  i  as 

(St  =  7.)  (III.2) 

whereas  the  complete  search  criteria  k  is  specified  as 

(51=7f)A...A((5n  =  7n)  (IH.3) 

B.  RELEVANCE  FUNCTION 

We  can  state,  without  loss  of  generality,  that  if  an  object  perfectly  matches  a 
search  criteria  k,  it  receives  a  score  of  1,  and  that  if  it  matches  perfectly  the  criteria  Ki 
for  dimension  i  then  it  receives  a  score  of  1  on  that  dimension.  Given  a  search  criteria, 
the  overall  relevance  score  9  of  an  object  is  computed  as  a  weighted  function — whose 
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values  fall  in  the  [0,1]  interval — of  its  relevance  scores  on  each  dimension.  The  general 
form  of  such  a  function  can  be  given  as: 


0(*l«)  =  X>i-0i(A|Ki)  (III. 4) 

i 

where  is  the  score  on  dimension  i  and  where  the  weights  Wi  sum  to  1.  Note 
that  instead  of  X)  one  could  use  some  other  aggregation  operator. 

To  complete  the  definition  of  a  relevance  function,  we  need  to  define  how  to 
compute  the  relevance  score  on  each  dimension.  Many  such  functions  are  possible, 
and  in  general  we  can  assume  that  they  work  by  measuring  how  the  object  is  related 
to  the  desired  class,  and  how  close  the  relation  is. 

•  Relevance:  In  our  taxonomic  system,  an  object  that  does  not  match  the  search 
criteria  exactly  (i.e.,  it  is  not  an  instance  of  the  desired  class)  may  still  be 
relevant  because  it  belongs  to  a  parent,  child  or  sibling  class  of  the  ideal  class. 
We  stated  these  relationships,  all  of  which  draw  from  the  base  relation  refines , 
in  Chapter  II  Section  A. 

Of  course,  being  a  parent  may  not  be  of  equal  relevance  as  being  a  child  or  a 
sibling.  In  each  case,  the  relevance  score  must  be  suitably  degraded.  Therefore, 
we  define  separate  (0,1)  parameters  av,  ac  and  os  as  the  degradation  multipliers 

for  objects  belonging  to  the  parent,  child  and  sibling,  classes  of  the  desired 
class. 

•  Distance:  Objects  that  belong  to  a  parent,  child  or  sibling  class  of  the  ideal 
class  are,  obviously,  only  one  level  from  the  ideal.  More  generally,  objects  that 
belong  to  ancestor  and  descendant  classes  (and  we  do  not  consider  cousins ) 
are  m  levels  removed  from  the  ideal  class,  and  their  relevance  should  decrease 
as  the  distance  increases. 

Here,  we  define  a  partial  function  mrej  to  compute  the  levels  between  two 
classes.  (Note  that  the  function  is  undefined  when  the  two  classes  are  not  on 
the  same  root  path.) 


7i  refines  72  — *• 

mref{l,l)  = 
mref(  7li72)  = 

mTef  (71 , 7)  +  mre  f  (7, 72  )  = 


72)  —  1 

(III  5) 

0 

(III.6) 

~mref( 72 >  7l) 

(III.  7) 

mref( 7l?  72) 

(III8) 

(III-9) 
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The  relevance  score  6l  on  dimension  i,  given  search  class  7 of  an  object  A 
which  belongs  to  class  7  is 


\ 


o™  ifmre/(7,7i>  0 
o™  ifmre/(7,7i<  0 
<rs  if  7  is  a  sibling  of  7* 


0  otherwise 


(III.  10) 


Recall  that  the  overall  relevance  score  6  is  computed  by  combining  the  scores 
0i  as  in  Equation  III. 4. 

It  may  now  be  obvious  that  the  relevance  function  9  resembles  a  probability 
function — the  relevance  score  0(A|/t)  can  be  interpreted  as  the  probability  that  an 
object  A  would  be  relevant  to  a  user  who  specified  the  search  criteria  k.  The  function 
can  easily  be  customized  by  users  via  the  following  input  parameters: 


•  Weights  Wi, ...  ,wn  for  dimensions 

•  Degradation  multipliers  ac,  <jp,  and  as 


C.  SEARCH  ALGORITHM:  EFFICIENCY  AND  COM¬ 
PLEXITY 

The  objective  of  a  search  algorithm  is  to  find  the  x  most  relevant  objects  in 
an  object  library,  based  on  a  variety  of  factors  listed  below,  but  where  x  itself  is  a 
parameter  that  cannot  be  specified  in  advance  with  any  degree  of  credibility.  The 
algorithm  must  employ  methods  to  prune  and  terminate  the  search  (worst  case  is  to 
compute  a  relevance  score  for  every  object  in  the  library,  but  this  is  not  desirable). 
For  example,  one  may  search  only  up  to  two  levels  from  the  desired  class.  Or,  perhaps, 
dynamically  determine  the  search  depth  in  a  dimension  as  some  function  of  the  weight 
of  that  dimension.  These  search  strategies  may  be  specified  as  meta-rules  in  the  search 
system,  and  can  make  the  search  much  more  efficient. 
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D.  COMPONENTS  OF  A  TAXONOMY-BASED  OBJECT 
CLASSIFICATION  AND  RETRIEVAL  SYSTEM 

We  have  developed  the  mathematical  and  taxonometric  framework  to  solve  this 
problem.  We  will  now  translate  that  framework  into  components  that  are  required  to 
perform  the  various  functions.  The  following  list  describes  the  components  in  broad 
terms.  Chapter  V  will  map  these  components  to  those  developed  for  this  thesis. 

•  Taxonomy  Browser 

This  module  allows  users  to  navigate  a  single  or  multi-dimensional  taxonomy. 
A  hierarchical  taxonomy  can  be  displayed  in  many  ways,  including  as  an  in¬ 
dented  list  (the  approach  employed  in  GAMS),  as  a  tree  or  hierarchy,  and  as 
a  cascading  list  (the  approach  employed  in  this  thesis). 

•  Object  Classification  Editor 

This  module  allows  users  (object  providers)  to  classify  newly  entered  objects, 
or  to  change  classification  of  existing  objects,  in  terms  of  the  classes  in  the  tax¬ 
onomy.  This  usually  requires  a  taxonomy  browser  to  allow  users  to  determine 
which  classes  in  the  taxonomy  are  most  suitable  for  the  object  to  be  classified. 

•  Search  Criteria  Editor 

This  module  allows  users  (consumers)  to  specify  the  search  criteria  to  be  used 
in  retrieving  objects  from  the  library.  The  criteria  are  limited  to  terms  con¬ 
tained  in  the  taxonomy. 

•  Search  Algorithm 

This  algorithm  retrieves  a  list  of  objects  from  the  library,  based  on  the  rele¬ 
vance  scores  of  objects,  computed  on  the  basis  of  the  search  criteria  specified 
by  the  user  and  the  relationships  in  the  taxonomy  and  object  databases.  For 
objects  that  do  not  exactly  meet  the  user’s  criteria,  the  relevance  is  computed 
based  on  the  degradation  parameters  for  inexact  matches. 

•  Search  Parameters  Editor 

This  module  lets  the  users  specify  the  weights  for  the  different  attributes,  as 
well  as  the  values  of  the  degradation  parameters  used  in  the  relevance  function 
in  the  search  algorithm. 

•  Search  Results  Visualizer 

This  module  displays  the  results  of  the  search  function.  Options  include  dif¬ 
ferent  ways  of  sorting  the  results,  recomputing  relevance  scores  if  user  changes 
some  of  the  parameter  values,  and  displaying  the  results  in  different  ways. 
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IV 


ANALYSIS  AND  DESIGN 


Recall  that  the  objectives  of  this  thesis  are  the  classification,  registration, 
search,  and  retrieval  of  multi-variable  digital  objects.  The  design  shown  here  achieves 
these  goals  within  the  limitations  that  will  be  discussed.  The  assumptions  and  deci¬ 
sions  that  were  made  during  the  analysis  and  design  process  are  discussed  here. 

A.  ASSUMPTIONS 

A  number  of  technologies  are  available  today  to  develop  a  WWW  applica¬ 
tion.  Performance  of  the  system  depends  both  on  the  development  technology  and 
the  technical  capabilities  of  the  user  (e.g.,  user’s  Web  browser  and  type  of  Internet 
connection).  In  developing  our  system,  we  made  certain  assumptions  about  user  ca¬ 
pabilities  before  selecting  the  development  technologies.  The  user  is  assumed  to  have 
a  Java  capable  Web  browser.  In  most  cases  this  translates  to  either  Internet  Explorer 
or  Netscape  Navigator  (versions  2.X  and  higher).  To  access  the  system  the  user  must 
have  some  knowledge  of  the  WWW.  Prior  knowledge  of  Decision  Support  Systems 
(DSS)  is  not  required.  Access  is  assumed  to  be  through  a  28.8  kb/s  modem. 

B.  DESIGN  CRITERIA 

The  design  criteria  are  also  goals  set  for  this  system.  The  design  criteria  are 
shown  in  the  following  list. 

•  Platform  Independence 

•  Usability 

•  Generalization 

Platform  independence  means  that  anyone  with  a  Java  capable  Web  browser 
and  Internet  access  will  be  able  to  use  this  system.  The  hardware,  operating  system, 
and  Web  browser  are  irrelevant.  The  Java  Virtual  Machine  (JVM)  will  handle  the 
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differences  that  have  made  platform  independence  impossible  in  the  past.  Java,  with 
its  promise  of  ’’Write  Once,  Run  Anywhere”,  is  the  primary  programming  language. 
[Ref.  10]  The  system  must  be  accessible  to  the  average  user  to  satisfy  the  second 
design  criteria. 

Usability ,  as  we  use  it  in  this  thesis,  is  defined  by  the  user.  The  graphical 
user  interface  (GUI)  is  intuitive  and  easy  to  navigate.  The  system  runs  over  the 
WWW  and  does  not  require  any  new  software  to  be  installed  on  the  client  machine. 
Efficiency  and  speed  are  acceptable  to  the  average  user.  This  factors  must  be  met  or 
people  will  not  use  the  system. 

Generalization  allows  the  system  to  display  any  taxonomy  that  conforms  to 
the  size  and  depth  limits.  The  DecisionNet  project  calls  for  a  five  variable,  four 
dimension  system.  All  five  variables  do  not  extend  to  four  dimensions  in  this  case. 
New  taxonomies  may  have  fewer  than  five  variables  and  fewer  than  four  dimensions. 
The  only  limit  imposed  is  the  upper  bound.  Beyond  the  taxonomy,  generalization 
also  means  that  new  CGI  scripts  can  be  called  to  achieve  the  registration  and  search 
functions  without  altering  the  Java  applets.  Input  parameters  to  the  applets  allow 
this  flexibility.  The  input  parameters  are  discussed  in  Appendix  C. 

C.  FUNCTIONALITY 

There  are  four  main  functions  performed  by  the  system.  They  are: 

•  Classification 

•  Registration 

•  Search 

•  Retrieval 

Classification  of  objects  is  a  function  performed  by  producers  of  decision  tech¬ 
nologies.  Classification  allows  the  producer  to  define  his  technology  within  the  De¬ 
cisionNet  taxonomy.  The  accurate  placement  within  the  taxonomy  is  essential  prior 
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to  registration.  The  applet’s  multi-level  display  capability  allows  the  use  of  the  full 
taxonomy  that  was  not  previously  possible.  The  taxonomy  allows  the  classification 
of  an  object  (DSS  in  this  case)  in  each  of  five  attribute  areas.  Each  attribute  may 
extend  as  many  as  four  levels  down  in  a  hierarchical  structure  that  is  defined  by  par¬ 
ent/child  relationships.  The  registration  function  takes  the  results  of  the  classification 
and  enters  them  in  the  technology  object  database. 

The  current  system  is  capable  of  search  by  one  variable  only,  with  binary  or 
yes/no  results.  An  algorithm  to  examine  all  of  the  possible  relationships  is  needed 
to  produce  a  relevancy  score.  This  would  give  a  relative  distance  from  the  search 
criteria  for  objects  of  possible  value  to  the  user.  A  user  also  requires  the  ability  to 
define  a  weight  for  each  attribute  as  well  as  degradation  multipliers  for  relationships 
other  than  an  exact  match.  These  relationships  are  defined  in  Chapter  II  Section  A. 

The  last  functional  area  is  retrieval.  This  could  also  have  been  labeled  display. 
The  search  results  must  be  returned  in  a  format  that  is  easily  interpreted  and  usable. 

D.  CLIENT  VS.  SERVER 

In  a  client/ server  environment  there  are  decisions  to  be  made  about  where  best 
to  locate  components  of  a  system.  Each  node  has  pros  and  cons  that  influence  design 
decisions.  A  node,  in  this  context,  is  simply  a  computer.  A  node  can  be  a  client,  a 
server,  or  both.  With  client  machines  getting  more  capability  every  day  there  is  a 
tendency  to  push  components  out  to  the  client  whenever  possible. 

This  client  centric  approach  works  well  when  bandwidth  is  not  a  concern.  The 
client/server  options  must  be  consistent  with  the  future  expansion  of  DecisionNet. 
The  system  must  be  scaleable  and  robust.  The  assumption  that  users  access  Deci¬ 
sionNet  through  a  modem  requires  that  download  time  be  a  consideration.  Server 
load  and  capabilities  are  another  driving  factor.  The  main  DecisionNet  server  is  a 
Pentium  (90  MHz)  with  24  MB  of  random  access  memory  (RAM).  The  current  hard¬ 
ware  is  adequate,  but  it  can  quickly  be  bogged  down  with  several  simultaneous  users. 
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Option  A  (Current  system)  -  Server  Intensive 
HTML  /  CGI  Scripts 

DB1  &  DB2 

Search  Algorithm  User 

(server)  (client) 

DBl=Taxonomy  DB 
DB2=Technology  Object  DB 


Considerations: 

-server  intensive 
-low  user  interactivity 
-no  browsing  of  die  taxonomy 
-no  relevancy  scores  of  searches 

Figure  3.  Time  Sequence  Diagram  -  Option  A 

With  these  factors  in  mind  we  examine  three  options. 

1.  Option  A  -  Server  Intensive 

The  first  option  is  a  description  of  many  current  CGI  systems.  The  process¬ 
ing  load  is  almost  entirely  on  the  server  node.  The  client  browser  does  little  more 
than  display  hypertext  mark-up  language  (HTML)  pages.  The  server  dynamically 
generates  HTML  pages  through  CGI  scripts.  Figure  3  describes  the  interaction  and 
the  location  of  various  components.  There  is  no  significant  processing  on  the  client 
node.  The  CGI  scripts  generate  content  dynamically,  but  it  is  static  once  it  reaches 
the  client.  This  produces  very  low  interactivity. 

2.  Option  B  -  Client  Intensive 

In  direct  contrast  to  Option  A,  Option  B  is  almost  entirely  on  the  client  node. 
The  server  is  little  more  than  a  file  and  database  server.  In  a  networked  environment 
with  10  MB/s  -  1  GB/s  data  transfer  rates  this  option  would  be  a  good  one.  With 
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Option  B  -  Client  Intensive 


Dnet 


User 


(server)  (client) 

I _ Request _ I 


Applet,  Search  Algorithm, 
DB1,  DB2 


Write  to  DB  for  Registration 


♦ 


t 


DBl=Taxonomy  DB 
DB2=Technology  Object  DB 


Considerations: 

-very  high  transmission  time 
-run  time  would  be  slow 
-possible  RAM  limitations  with 
Java  Applet  security  features 


Figure  4.  Time  Sequence  Diagram  -  Option  B 


users  accessing  the  system  with  28.8  kb/s  modems  it  will  prove  to  be  unusable  due 
to  the  long  transmission  times.  Figure  4  describes  the  interaction  and  the  location  of 
various  components. 

As  both  the  taxonomy  and  object  databases  grow,  the  situation  will  get  worse. 
The  security  features  of  Java  applets  could  become  a  limiting  factor.  By  design, 
applets  are  downloaded,  stored,  and  run  entirely  in  the  client’s  RAM.  A  security 
feature  of  applets  is  their  inability  to  read  or  write  from  any  drive  except  the  server 
from  which  they  were  launched.  With  large  databases  and  applet  code,  a  client  may 
not  be  able  use  the  system  due  to  memory  limitations.  The  ability  to  access  a  client’s 
local  drive  is  being  considered  for  a  future  Java  release. 

3.  Option  C  -  Goal  Architecture 

Option  C  combines  the  benefits  of  Options  A  and  B.  The  components  whose 
functions  do  not  rely  on  repeated  server  communications,  and  can  be  economically 
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Figure  5.  Time  Sequence  Diagram  -  Option  C 


transmitted,  are  located  on  the  client  node.  Functions  that  fail  either  of  those  criteria 
are  located  on  the  server  node.  This  approach  is  a  three  tiered  client/server  architec¬ 
ture.  [Ref.  11]  The  taxonomy  database  and  the  applet  code  reside  on  one  server.  The 
technology  object  database  and  search  algorithm  reside  on  a  second  server.  Commu¬ 
nication  is  limited  once  the  applet  is  loaded  onto  the  client.  Figure  5  describes  the 
interaction  and  the  location  of  various  components. 

There  are  several  factors  that  make  the  three  tiered  approach  attractive.  The 
taxonomy  database  is  closely  tied  to  the  applet.  It  is  also  relatively  small  and  stable. 
It  is  much  more  efficient  to  send  the  taxonomy  with  the  applet  that  will  use  it  than 
to  have  repeated  calls  back  to  the  server.  This  approach  allows  repeated  browsing 
with  no  additional  overhead. 

The  search  algorithm  is  closely  tied  to  the  technology  object  database.  This 
database  could  become  quite  large  resulting  in  transmission  delays  if  it  were  sent  to 
the  client.  The  search  algorithm  could  also  be  a  bottle-neck.  The  search  algorithm 
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Figure  6.  Goal  Architecture 


is  computationally  intensive  and  makes  repeated  queries  to  several  databases.  These 
facts,  combined  with  the  transmission  time,  could  make  the  search  performance  un¬ 
acceptable. 

E.  THE  ALL-JAVA  SOLUTION 

Sun’s  Java  Developer’s  Kit  (JDK)  1.1.2  supports  a  three  tiered  client/  server 
architecture.  The  additions  of  Remote  Method  Invocation  (RMI)  and  Java  DataBase 
Connectivity  (JDBC)  make  the  three  tiered  design  possible.  The  applet  security 
restrictions  are  enforced  by  only  allowing  the  applet  to  communicate  with  the  server 
that  launches  it.  The  applet  server  makes  calls  to  the  database  server  on  the  applet’s 
behalf.  The  applet  is  limited  in  what  it  can  do  because  the  methods  available  to  it 
are  defined  in  the  interface  running  on  the  applet  server.  The  applet  server  acts  as 
an  intermediary  between  the  applet  and  the  object  database  server. 

This  design  meets  the  technical  goals  that  we  established  and  took  advantage  of 
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the  strengths  of  both  client  and  server  nodes.  However,  the  goal  architecture  currently 
fails  the  test  of  usability.  The  only  browser  that  currently  supports  JDK  1.1.2  is 
Sun’s  HotJava  browser.  Netscape  Communicator  and  Microsoft  Internet  Explorer 
dominate  the  market  of  Web  browsers.  Neither  one  has  fully  implemented  the  latest 
Java  release  and  neither  currently  supports  this  design.  Chapter  V  describes  the 
actual  implementation  and  discusses  areas  where  it  differs  from  the  ideal  technical 
solution  shown  here. 
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V 


IMPLEMENTATION 


As  discussed  in  Chapter  IV,  the  goal  of  an  all-Java,  three  tiered  client  server 
solution  is  not  currently  feasible.  Without  Web  browser  support,  the  design  would  not 
meet  user  needs,  and  thus  fail  the  second  design  criteria  of  usability.  The  decision  was 
made  to  modify  the  design  to  include  a  CGI  based  search  algorithm  on  the  database 
server.  A  suitable  existing  algorithm  could  not  be  located.  The  existing  DecisionNet 
system  consists  of  CGI  scripts  written  in  Object  Pascal  using  the  Delphi  development 
tool.  To  maintain  consistency  with  the  existing  system  the  search  engine  is  written 
in  Delphi. 

Figure  7  illustrates  the  component  location  and  system  interaction.  The  only 
non-Java  component  is  the  search  algorithm  which  will  be  discussed  further  in  Sec¬ 
tion  C. 


Java  Integration  with  existing  Dnet  Components 

1  -  Object  Library  Browser  (future  project-java  applet) 

2  -  Taxonomy  Browser  (java  applet) 

3  -  Object  Classification  Editor  (utilizes  #2) 

4-  Registration  Object  (existing  Delphi  CGI  script-uses  #3) 

5  -  Search  Criteria  Editor  (utilizes  #2) 
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A.  TAXONOMY  DATA  FILES 

The  original  design  called  for  the  taxonomy  to  be  read  dynamically  from  the 
database.  The  relatively  static  nature  of  the  taxonomy  allows  the  information  to  be 
stored  in  data  files.  If  the  applet  were  to  query  the  database  it  would  have  to  be 
launched  from  the  same  server  to  satisfy  applet  security  restrictions.  We  felt  that 
there  was  no  advantage  to  adding  this  restriction.  Updating  the  taxonomy  involves 
nothing  more  than  editing  a  text  file.  By  not  accessing  the  database,  the  download 
time  is  greatly  reduced.  We  divide  the  four  levels  of  the  taxonomy  into  separate  data 
files.  The  first  level  is  read  in  and  displayed  while  the  others  are  loading  instead  of 
waiting  for  the  entire  taxonomy  before  display. 

The  data  files  are  text  files  with  a  standard  format.  The  parent  term  starts  at 
character  position  1  and  the  child  term  starts  at  character  position  39.  This  format 
is  required  by  the  applet  for  correct  parsing  of  the  data.  This  format  accommodates 
the  longest  string  in  the  taxonomy  in  addition  to  a  small  buffer.  This  design  feature 
allows  any  taxonomy  (within  design  specifications)  to  be  displayed  with  this  system. 


B.  JAVA  CLASSES 

Java  source  code  has  a  .java  extension.  Compiled  Java  code  has  a  .class  ex¬ 
tension.  A  class  file  is  analogous  to  an  executable  file  in  other  languages  although  it 
can  not  run  without  the  JVM.  Java’s  platform  independence  is  achieved  by  compil¬ 
ing  source  code  to  an  intermediate  level  known  as  byte  codes.  The  byte  codes  are 

object  code  for  the  JVM.  The  JVM  interprets  the  object  code  to  execute  on  the  local 
platform. 

The  following  is  a  description  of  each  class’  function  and  its  interaction  with 
the  overall  system.  An  object  is  an  instance  of  a  Java  class.  The  distinction  is  small 
and  they  are  often  used  interchangeably.  The  term  object  can  also  be  used  as  a  generic 
label  for  a  decision  technology  in  this  system.  We  refer  to  attributes  as  instances  of 
variables  in  much  the  same  way.  A  variable  is  a  generic  term  such  as  ’Problem  Area’. 
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An  attribute  is  a  child  of  that  variable  describing  a  particular  technology  object. 
Where  appropriate,  the  DecisionNet  Java  Objects  refer  to  the  general  Components 
described  in  Chapter  III  Section  D. 

1.  Dnet_Reg.class 

This  applet  allows  a  producer  to  explore  the  taxonomy  and  decide  where  his 
decision  technology  fits  into  it.  This  object  implements  the  Object  Classification 
Editor.  (See  Chapter  III  Section  D)  Once  the  technology  is  correctly  classified,  the 
applet  interfaces  with  an  existing  CGI  script  (regteca.exe)  [Ref.  7]  to  complete  the 
registration.  The  applet  allows  specification  down  to  four  levels  for  each  variable. 
The  applet  captures  user  information  from  the  HTML  page  that  launches  it.  The 
user  information  is  required  by  the  CGI  script  (regteca.exe).  It  utilizes  the  taxonomy 
object  as  its  main  GUI. 

2.  Dnet_Search.class 

This  applet  allows  a  consumer  to  explore  the  taxonomy  and  specify  search 
criteria  for  the  five  variables.  This  object  serves  as  the  Search  Criteria  Editor.  (See 
Chapter  III  Section  D)  The  applet  allows  specification  down  to  four  levels  for  each 
variable.  The  applet  utilizes  the  taxonomy  object  as  its  main  GUI.  It  passes  control 
and  the  search  criteria  to  the  weights  object. 

3.  DnetJBrowse.class 

This  applet  allows  a  consumer  to  browse  the  taxonomy  .  This  object  serves 
as  the  Taxonomy  Browser.  (See  Chapter  III  Section  D)  The  applet  allows  browsing 
down  to  four  levels  for  each  variable.  The  applet  utilizes  the  taxonomy  object  as  its 
main  GUI. 

4.  Taxonomy,  class 

The  taxonomy  object  is  utilized  by  all  three  applets.  It  is  the  main  GUI  that 
displays  the  taxonomy  and  highlights  user  selections.  The  user  controls  the  display 
by  double  clicking  the  left  mouse  button  within  a  displayed  list.  If  there  are  any 
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children  of  the  selected  term  in  the  taxonomy,  they  are  displayed  in  the  adjacent  list. 
This  cascading  refinement  is  highlighted  in  the  text  boxes  above  the  lists. 

Appendix  C  contains  a  list  of  variables  that  are  passed  to  the  taxonomy  object 
when  one  of  the  three  applets  calls  it.  Any  parameters  that  do  not  apply  are  sent  as 
a  single  space.  All  of  these  parameters  originate  in  the  HTML  page  that  launches  the 
applet.  The  applet  reads  them  and  passes  the  appropriate  parameters  to  the  other 
objects  (taxonomy,  weights,  grep,  etc.)  as  needed. 

5.  Weights,  class 

The  weights  object  accepts  the  search  criteria  and  allows  the  user  to  adjust 
the  variable  weights  and  degradation  multipliers  used  by  the  search  algorithm.  This 
object  serves  as  the  Search  Parameters  Editor.  (See  Chapter  III  Section  D)  Default 
values  are  provided  through  the  input  parameters.  Equal  weight  is  given  to  each 
variable  and  degradation  multipliers  are  set  to  the  expected  probable  value  of  a  given 
relationship.  The  weights  object  passes  control  to  the  Search  Algorithm  (Indexed.exe) 
described  in  Section  C. 

6.  Search_Results.class 

The  Search-Results  object  accepts  the  output  from  the  Indexed.exe  script  for 
display  within  the  applet.  This  object  serves  as  the  Search  Results  Visualizer.  (See 
Chapter  III  Section  D)  The  datastream  is  parsed  and  formatted  using  control  char¬ 
acters  placed  in  the  stream  by  the  Indexed.exe  script.  The  user’s  search  criteria  and 
variable  weights  are  returned  for  review.  Each  relevant  technology  is  displayed  with 
a  total  score  as  well  as  individual  attribute  scores.  This  allows  the  user  to  see  which 
attributes  produced  a  relationship,  and  what  type  of  relationship  it  is. 

7.  Reg_Complete.class 

The  Reg-Complete  object  is  a  simple  dialog  screen  that  displays  the  success 
or  failure  of  various  operations.  It  is  utilized  by  the  DNET-Reg  and  DNETSearch 
applets. 
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8.  MultiLineLabel.class 

At  the  time  of  coding,  the  Java  language  did  not  define  a  label  of  more  than 
one  line  of  text.  This  object  provides  that  functionality.  [Ref.  10] 

9.  Grep.  class 

This  object  is  slightly  modified  from  the  cited  source.  Its  only  function  is  to 
discard  lines  that  do  not  contained  a  given  string.  It  receives  lines  of  text  from  the 
GrepInputStream  object  along  with  the  string  to  be  matched.  [Ref.  10] 

10.  GrepInputStream. class 

This  object  is  slightly  modified  from  the  cited  source.  Its  only  function  is  to 
read  lines  from  an  input  stream.  It  passes  each  line  to  the  Grep  object  along  with  the 
string  to  be  matched.  [Ref.  10] 

11.  QueryString.class 

This  object  concatenates  the  variables  into  one  string  to  be  sent  to  either  the 
registration  ( regteca.exe )  or  search  (Indexed. exe)  CGI  script. 

C.  DELPHI  SEARCH  SCRIPT 

The  only  component  of  this  system  that  is  not  implemented  in  Java  is  the 
search  algorithm.  Once  the  decision  to  modify  the  all- Java  solution  was  made,  a 
Java  search  algorithm  did  not  offer  any  advantages.  The  driving  factor  in  going  to 
a  native  code  solution  was  speed.  The  search  algorithm  is  computationally  intensive 
and  makes  repeated  queries  to  several  database  tables.  The  performance  would  be 
unacceptable  given  the  current  speed  of  Java  code.  Java  code  can  be  significantly 
slower  than  C  code  on  average.  [Ref.  10]  Sun  is  currently  working  to  improve  the 
performance  with  the  introduction  of  a  Just-in-Time  (JIT)  Compiler. 

1.  Indexed.exe 

This  is  the  implementation  of  the  Search  Algorithm.  (See  Chapter  III  Sec¬ 
tion  D)  The  search  algorithm  is  designed  to  compute  a  relevancy  score  for  technolo- 
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giss  that  may  be  of  interest  to  a  consumer  conducting  a  search.  The  goal  is  to  limit 
the  number  of  records  that  need  to  be  processed  without  discarding  any  that  may 
be  useful.  The  initial  screening  looks  to  find  at  least  one  direct  match  between  the 
search  criteria  and  a  record  attribute.  Those  records  with  a  match  are  then  eligible 
to  be  scored.  As  the  number  of  records  in  the  Technolo.db  [Ref.  7]  database  increases 
this  screening  can  be  increased  to  require  two  or  more  matches  before  evaluating  the 
record’s  attribute  relationships. 

For  every  record  that  is  eligible,  the  algorithm  checks  each  attribute  to  deter¬ 
mine  if  a  relationship  exists.  The  order  of  precedence  follows: 

•  Search  Criteria  =  ALL,  indicating  no  preference 

•  Search  Criteria  is  a  direct  match  of  the  Attribute 

•  Search  Criteria  is  a  child  of  the  Attribute 

•  Search  Criteria  is  a  parent  of  the  Attribute 

•  Search  Criteria  is  a  sibling  of  the  Attribute 

•  Search  Criteria  is  a  descendant  of  the  Attribute 

•  Search  Criteria  is  a  ancestor  of  the  Attribute 

Queries  are  conducted  through  boolean  gates  that  stop  the  process  once  a 
relationship  has  been  established.  Every  eligible  record  is  assigned  five  attribute 
scores.  Once  all  of  the  relationships  are  established  the  algorithm  computes  a  total 
score  for  each  record.  The  relevancy  score  is  a  summation  of  the  variable  weights 
multiplied  by  the  attribute  score.  This  is  shown  notationally  in  Equation  III.4. 

This  implementation  takes  advantage  of  the  strengths  of  each  node  of  the 
client/server  environment.  The  components  are  closely  and  logically  tied  to  their  data 
sources.  Integration  with  the  current  system  drove  the  continued  use  of  CGI  scripts. 
For  most  functions  CGI  scripts  are  efficient  and  robust,  but  they  lack  interaction. 
The  combination  of  Java  Applets  and  CGI  scripts  offers  a  reasonable  alternative. 
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VI 


SYSTEM  TOUR 


The  classification,  registration,  search,  and  retrieval  functions  are  visual  and 
intuitive.  Once  the  applet  is  launched,  a  mouse  is  generally  all  that  is  required  to 
navigate  among  the  functions.  The  only  time  that  the  keyboard  is  required  is  to 
change  the  default  values  in  the  search  engine.  The  following  sections  show  the  flow 
of  control  through  the  system  as  well  as  the  various  screens  that  a  user  will  see. 

A.  TECHNOLOGY  REGISTRATION 

Producers  of  decision  support  technologies  use  this  applet  to  correctly  classify 
their  decision  technology  within  the  DecisionNet  taxonomy.  (See  Figure  8)  All  of 
the  user  information  is  supplied  to  the  applet  by  the  DecisionNet  CGI  script  that 
produced  the  HTML  page.  Once  the  object  classification  is  complete,  the  user  presses 
the  ’Submit  for  Registration’  button  and  control  passes  to  the  registration  CGI  script 
(regteca.exe).  The  success  or  failure  of  the  registration  process  is  displayed  in  Figure  9. 

B.  CONSUMER  SEARCH 

This  applet  allows  a  consumer  to  conduct  a  detailed  search  of  the  technology 
object  database.  The  search  engine  allows  the  user  to  be  as  vague  or  as  specific  as  he 
would  like.  He  may  specify  any  or  all  of  the  attributes  that  he  is  interested  in.  The 
default  value  of  ’ALL’  will  return  a  much  wider  range  of  responses  than  will  a  more 
specific  selection. 

The  Search  Criteria  Editor  utilizes  the  same  GUI  shown  in  Figure  8  for  its 
initial  display.  In  the  search  configuration,  the  labels,  instructions,  and  button  func¬ 
tions  have  changed  to  reflect  this  role.  This  GUI  allows  the  user  to  view  and  select 
from  the  entire  taxonomy.  Once  the  terms  have  been  selected,  the  consumer  pressed 
the  ’Define  Search  Weights’  button.  Control  then  passes  to  the  Search  Parameters 
Editor  shown  in  Figure  10. 
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Figure  8.  Object  Classification  Editor 

The  Search  Parameters  Editor  allows  a  consumer  to  further  refine  their  search. 
If  certain  variables  are  more  or  less  important,  the  default  weights  should  be  changed. 
The  five  variable  weights  must  sum  to  1.0  or  the  results  will  be  meaningless.  The 
degradation  factors  allow  a  consumer  to  state  the  utility  of  various  relationships 
that  may  exist  between  their  search  criteria  and  object  attributes.  The  degradation 
multiplier  is  applied  as  follows: 

•  If  the  criteria  is  a  child  of  the  attribute  then  the  attribute  receives  a  score 
equal  to  the  child  degradation  multiplier. 

•  If  the  criteria  is  a  parent  of  the  attribute  then  the  attribute  receives  a  score 
equal  to  the  parent  degradation  multiplier. 

•  If  the  criteria  is  a  sibling  of  the  attribute  then  the  attribute  receives  a  score 
equal  to  the  sibling  degradation  multiplier. 
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Figure  9.  Results  Dialog  Window 

•  If  the  criteria  is  a  descendant  of  the  attribute  then  the  attribute  receives  a 
score  equal  to  the  child  degradation  multiplier  squared. 

•  If  the  criteria  is  a  ancestor  of  the  attribute  then  the  attribute  receives  a  score 
equal  to  the  parent  degradation  multiplier  squared. 

Once  the  consumer  has  fully  specified  his  search,  he  uses  the  ’Submit  to  Search 
Engine’  button  to  launch  the  search.  The  search  algorithm  is  run  through  a  CGI 
script  and  produces  an  output  file  that  is  returned  to  the  applet.  The  script  ends 
each  line  with  the  control  characters  This  allows  the  applet  to  parse  the  stream 
of  characters  and  recreate  the  form  of  the  output  file.  The  results  are  display  in  the 
Search  Results  Visualizer  shown  in  Figure  11. 


33 


Ptea«u*elhi*  apple*  to  specify  your  ~*  ““ 

pr«fer©nc«5  and  cfcwctiva*  for  \ht  teerch  afeorthm, 

Rrew  *Submft  to  Search  Enghe'  to  bunch  your  joarch. 

Thfe  Applet  k  wtfcen  irUava  By  LT  Ohs  Cagrati. 

VW  *  Venable  Weight  (must  sum  to  VO) 

COM  *  Chid  Degradation  WuKpfef 
PDM  *  Parent  Degradation  Muftpfer 
SDM  »  SWng  Degradation  Mufcipfc# 

DefaUt  Values  are  shorn  Advanced  users  mrry  define 
orttora  values  here.  Degradation  Muftipters  must  be  h 
dw  interval  [0/1 ).  Higher  vaKres  rrfeate  a  stronger  preference 
for  the  selected  item  onfc.  lower  vaMes  alow  the  search  to 
retur*  m ora  possibte  antwm  which  may  have  a  tower  relevancy 


VW 

COM 

PDM 

SDM 

PrcbtomAiea  j.2 

iC . 

lb ' ' 

Is 

Functional  Aiea 

lb . 

u 

Industry  Type  J.2 

jpc: 

jk_ 

J-6  J 

Organisation  Type  j/?  " 

IpT^ 

lb . . 

fl  j 

Solution  Area  j.2 

jE 

!< 

1.6. 

Figure  10.  Search  Parameters  Editor 

C.  TAXONOMY  BROWSING 

This  is  the  simplest  of  the  three  applets.  It  is  used  to  browse  the  entire  five 
variable,  four  dimensional  taxonomy.  The  user  can  explore  the  possibilities  and  depth 
available  in  the  system.  Once  the  browser  applet  is  downloaded,  there  is  no  need  for 
further  communication  with  the  server.  It  will  run  entirely  on  the  client.  Figure  8 
again  shows  the  taxonomy  object.  In  the  browser  configuration,  the  labels,  directions, 

and  button  functions  have  changed  to  reflect  this  role.  The  layout  and  control  are 
identical. 
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Figure  11.  Search  Results  Visualizer 


VII.  CONCLUSIONS 


A.  CONTRIBUTIONS 

This  thesis  defines  a  methodology  for  classifying,  registering,  searching,  and 
retrieving  multi-variable  objects  in  a  digital  repository.  The  methodology  includes 
the  definition  of  relationships  that  exist  in  a  parent/child  taxonomy.  The  compo¬ 
nents  required  to  implement  such  a  system  are  described  in  general  terms  and  are 
demonstrated  within  DecisionNet.  This  framework  can  be  applied  to  any  system  that 
classifies  objects  with  a  taxonomy  and  stores  them  in  a  digital  library. 

The  system  developed  for  DecisionNet  implements  this  methodology.  It  is 
both  a  testbed  and  a  proof  of  concept.  The  ability  to  utilize  the  full  taxonomy 
greatly  enhances  DecisionNet’s  ability  to  bring  producers  and  consumers  of  decision 
technologies  together.  The  generalization  that  is  integral  to  this  thesis  enables  it  to 
be  applied  to  any  systems  that  relies  on  a  taxonometric  classification  scheme.  The 
number  of  attributes  and  levels  can  be  increased  in  the  future  to  accommodate  a 
larger  taxonomy. 

B.  LESSONS  LEARNED 

The  following  is  a  list  of  lessons  learned  along  the  thesis  path. 

•  Repositories  and  code  reuse  hold  a  lot  of  promise  for  future  projects.  Java  is 
not  yet  at  this  stage. 

•  The  conceptual  understanding  of  what  object  oriented  programming  is  and 
what  it  offers  does  not  come  immediately.  This  basic  understanding  is  required 
before  any  real  progress  can  be  made. 

•  Each  decision  made  during  analysis,  design,  and  implementation  effects  the 
options  available  later  in  the  development  cycle.  A  good  example  is  a  naming 
convention.  Planning  and  thought  need  to  go  into  variable  and  object  names 
before  they  become  too  cumbersome  to  change. 

•  Documentation  should  be  written  simultaneously  with  the  code.  This  proved 
very  beneficial  when  trying  to  integrate  Java  code  with  Delphi  code. 
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•  Java  is  not  a  mature  language.  Java  is  developing  quickly,  but  it  has  not 
reached  the  maturity  level  of  many  object  oriented  languages.  Java  lacks  a 
good  IDE  that  allows  for  the  drag  and  drop  construction  of  GUIs.  There  are 
attempts  being  made,  but  they  currently  lag  behind  those  developed  for  other 
languages. 

•  The  key  to  running  an  applet  within  a  web  browser  is  the  JVM.  The  JVM 
should  interpret  the  applet  bytecodes  to  run  on  any  hardware  and  produce 
the  same  output  regardless  of  the  platform.  This  is  not  the  case.  There 
is  a  lack  of  standardization  in  the  JVM  implementation.  This  system  was 
tested  on  several  hardware  platforms  with  different  web  browser  combinations. 
The  results  were  inconsistent.  The  basic  functionality  was  adequate,  but  the 
display  was  awkward  at  times. 


C.  LOOKING  FORWARD 

This  Thesis  addresses  and  solves  several  areas  that  were  identified  in  past 

DecisionNet  thesis  projects.  The  following  topics  are  areas  that  remain  for  further 
research. 


1.  Search  Algorithm 

The  search  algorithm  developed  in  this  thesis  establishes  relationships  for  each 
attribute  of  a  record  that  passes  its  initial  screening.  This  works  well  in  the  current 
environment.  As  the  object  database  grows  in  size,  the  efficiency  of  this  approach 
will  become  a  limiting  factor.  A  clever  indexing  scheme  will  greatly  improve  the 
search  efficiency.  Another  possibility  is  to  establish  relationships  within  the  taxonomy 
and  include  them  as  an  attribute  in  the  taxonomy  database.  Chapter  III  Section  C 
describes  the  dynamic  determination  of  search  depth  based  on  search  weight  input. 
This  will  also  improve  the  algorithm’s  efficiency. 

2.  Search  Results  Visualizer 

The  Search  Results  Visualizer  is  currently  a  display  of  the  output  text  file  from 
the  search  algorithm’s  CGI  script.  This  data  could  be  sorted  and  displayed  in  any 
number  of  ways  that  may  be  helpful  to  a  consumer.  The  following  is  a  list  of  possible 
representations  that  would  greatly  enhance  the  impact  and  usability  of  the  returned 
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data. 


•  Display  total  scores  first,  and  allow  the  user  to  drill  down  to  review  individual 
attribute  scores  of  promising  technologies 

•  A  comparative  bar  chart  to  visually  compare  the  relevance  of  different  tech¬ 
nologies  against  each  other  and  against  the  ideal  case  of  1.0 

•  A  pie  chart  to  display  the  user  defined  variable  weights 

•  A  sliding  scale  that  could  be  dragged  with  a  mouse  to  perform  sensitivity 
analysis  on  weights  and  degradation  factors 

An  applet  is  the  perfect  vehicle  to  handle  these  tasks  on  the  client  machine. 

3.  Three  Tiered  Client/Server 

The  implementation  of  the  three  tiered  client  server  design  will  be  possible 
in  the  next  12-24  months.  As  the  Java  language  and  the  support  for  it  grows, 
an  all-Java  solution  will  take  full  advantage  of  distributed  computing  and  storage  of 
information. 

4.  Help  Menus 

The  ability  to  right  mouse  click  on  a  term  or  component  would  greatly  add 
to  the  usability  of  the  system.  There  are  many  technical  and  mathematical  terms  in 
the  taxonomy  that  will  not  be  familiar  to  the  average  user.  Online  amplification  and 
definition  would  increase  the  effectiveness  of  the  classification  and  search  functions 
by  answering  questions  as  the  arise. 


39 


APPENDIX  A.  SYMBOLS  AND  ACRONYMS 


Symbol  = 

>  Name 

A 

Delta 

delta 

r 

Gamma 

7 

gamma 

K 

kappa 

A 

Lambda 

A 

lambda 

n 

Omega 

UJ 

omega 

$ 

Phi 

Psi 

i> 

psi 

a 

sigma 

6 

theta 

Acronym^ 

=>  Meaning 

CGI 

Common  Gateway  Interface 

DNET 

DecisionNet 

DSS 

Decision  Support  System 

GB 

Gigabit 

GUI 

Graphical  User  Interface 

HTML 

Hyper  Text  Mark-Up  Language 

IDE 

Integrated  Development  Environment 

JIT 

Just  in  Time 

JVM 

Java  Virtual  Machine 

JDBC 

Java  DataBase  Connectivity 

JDK 

Java  Developer’s  Kit 

KB 

Kilobit 

MB 

Megabit 

MHz 

Megahertz 

OS 

Operating  System 

RAM 

Random  Access  Memory 

RMI 

Remote  Method  Invocation 

URL 

Uniform  Resource  Locator 

WWW 

World  Wide  Web 
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APPENDIX  B.  TIPS  FOR  SYSTEM 
ADMINISTRATION 


The  system  design  is  focused  on  adaptability  beyond  DecisionNet.  It  is  able  to 
display  and  manipulate  any  taxonomy  that  fits  within  the  five  variable,  four  dimension 
limit.  This  is  achieved  by  passing  parameters  from  an  HTML  page  into  each  applet. 
A  standard  list  of  parameters  is  passed  each  time  an  applet  is  called.  Variables  that 
do  not  apply  are  passed  as  a  blank  space.  An  example  of  this  generality  is  the  URL 
parameter.  The  implementation  is  not  tied  to  any  URL  or  domain  name.  If  the  class 
files,  data  files,  or  database  are  transferred  to  another  server  it  requires  only  a  change 
to  the  HTML  parameter. 

The  naming  conventions  and  database  design  of  DecisionNet  were  left  un¬ 
touched.  The  variable  names  internal  to  the  Java  code  are  in  some  cases  specific  to 
DecisionNet.  This  is  transparent  to  the  user  because  the  actual  values  are  fed  from 
the  HTML  page.  Each  parameter  is  discussed  in  detail  in  Appendix  C.  Appropriate 
values  are  defined  were  applicable. 

Each  level  of  the  taxonomy  has  its  own  data  file.  This  was  done  to  logically 
separate  the  taxonomy  levels  and  to  speed  retrieval.  The  data  files  must  conform 
to  the  standard  format.  The  parent  term  starts  at  character  position  1,  followed  by 
the  child  term  at  character  position  39.  The  child  term  must  be  followed  by  a  line 
break.  This  seemingly  arbitrary  number  is  two  characters  past  the  longest  entry  in  the 
taxonomy.  In  the  event  that  a  taxonomy  contains  strings  longer  than  38  characters, 
the  code  of  Grep.class  would  need  to  be  altered  and  recompiled.  The  data  files  are 
stored  as  .txt  files,  and  must  be  located  in  a  WWW  accessible  directory  along  with 
the  Java  class  files. 

The  Java  code  was  developed  in  the  Microsoft  Visual  J++  integrated  devel¬ 
opment  environment  (IDE).  If  it  becomes  necessary  to  change  any  of  the  Java  source 
code  it  should  be  done  through  the  IDE.  The  Dnet  project  file  (Dnet.dsw)  contains 
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links  to  all  of  the  Dnet  source  files.  The  files  can  be  recompiled  as  a  project  by  se¬ 
lecting  the  Rebuild  All  function  from  the  ’Build’  pull  down  menu.  The  development 
platform  was  a  Pentium  (166  Mhz)  with  64  MB  of  RAM.  The  operating  system  (OS) 
was  Windows  NT  Workstation  4.0.  The  primary  Web  browser  was  Microsoft  Internet 
Explorer  3.02.  Netscape  3.0  and  HotJava  were  used  for  test  and  evaluation  only. 
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APPENDIX  C.  APPLET  PARAMETERS 


•  PARAM  NAME=title  Jnput  VALUE=”  DecisionNet  Registration  Applet”  This 
is  the  screen  title  that  appears  in  the  top  left  corner  of  the  taxonomy  screen. 
This  may  be  changed  at  will. 

•  PARAM  NAME=LeftButtonLabel_input  VALUE=”  Submit  for  Registration” 
There  are  only  three  acceptable  values  for  this  paramater. 

-  Dnet_Reg.class  requires  the  string  ’’Submit  for  Registration”. 

-  Dnet  .Search,  class  requires  the  string  ”  Define  Search  Weights” . 

-  Dnet JBrowse. class  requires  the  string  ’’Return  to  DecisionNet” . 

These  strings  are  used  to  tailor  the  taxonomy  object  based  on  the  applet  that 
called  it.  If  anything  other  than  these  strings  is  used,  the  left  button  of  the 
taxonomy  screen  will  not  function. 

•  PARAM  NAME=ProviderID_Input  VALUE—’ corgnati”  This  paramater  is 
captured  from  a  CGI  script  and  inserted  into  HTML.  Is  a  system  defined 
user  name.  It  is  used  by  the  registration  applet. 

•  PARAM  NAME=ConsumerID  Jnput  VALUE=”  ”  This  paramater  is  captured 
from  a  CGI  script  and  inserted  into  HTML.  This  is  a  system  defined  user  name. 
It  is  used  by  the  search  applet. 

•  PARAM  NAME=TechID -Input  VALUE=”14”  This  paramater  is  captured 
from  a  CGI  script  and  inserted  into  HTML.  It  is  an  index  to  track  producers 
with  multiple  technologies  registered. 

•  PARAM  NAME=TechName Jnput  VALUE=”Test”  This  paramater  is  cap¬ 
tured  from  a  CGI  script  and  inserted  into  HTML.  This  is  whatever  the  pro¬ 
ducer  wants  it  to  be. 

•  PARAM  NAME=tObjectType  Jnput  VALUE=” Solver”  This  parameter  is 
captured  from  a  CGI  script  and  inserted  into  HTML.  This  is  a  relic  from  the 
original  implimentation.  It  is  included  only  to  maintain  integrity  with  the 
existing  database  and  CGI  scripts.  The  acceptable  values  for  DecisionNet  are: 

-  ALL 

-  Algorithm 

-  Data  Set 

-  Decision  Support  System 
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-  Example 

—  Model  Schema 

-  Modeling  Language 

—  Solver 

•  PARAM  NAME=tURLJnput  VALUE=”http://131. 120.39.60”  This  parame¬ 
ter  is  captured  from  a  CGI  script  and  inserted  into  HTML.  It  is  the  URL  of 
the  producer’s  technology. 

•  PARAM  NAME=ExcInd_Input  VALUE=”Independent”  This  parameter  is 
captured  from  a  CGI  script  and  inserted  into  HTML.  This  is  a  flag  used  by 
AMPL  technologies.  It  is  included  only  to  maintain  integrity  with  the  existing 
database  and  CGI  scripts. 

•  PARAM  NAME=PurposeJnput  VALUE=”none”  This  parameter  is  captured 

from  a  CGI  script  and  inserted  into  HTML.  It  is  a  narrative  description  of  the 
technology. 

•  PARAM  NAME  Comments  Jnput  VALUE=’?none”  This  parameter  is  cap¬ 
tured  from  a  CGI  script  and  inserted  into  HTML.  It  is  a  narrative  that  allows 
for  any  additional  information. 

•  PARAM  NAME=ProviderID_db  Jnput  VALUE  ”  This  parameter  repre¬ 
sents  the  field  name  in  the  associated  database.  It  is  passed  to  the  CGI  scripts 
where  required. 

•  PARAM  NAME=ConsumerID_db  Jnput  VALUE  =”  ”  This  parameter  repre¬ 
sents  the  field  name  in  the  associated  database.  It  is  passed  to  the  CGI  scripts 
where  required. 

•  PARAM  NAME=TechID_db  Jnput  VALUE  =”  ”  This  parameter  represents 
the  field  name  in  the  associated  database.  It  is  passed  to  the  CGI  scripts 
where  required. 

•  PARAM  N AME=TechN ame_db Jnput  VALUE  =”  ”  This  parameter  repre¬ 
sents  the  field  name  in  the  associated  database.  It  is  passed  to  the  CGI  scripts 
where  required. 

•  PARAM  N AM E=t Obj  ectT ype_db Jnput  VALUE  =”  ”  This  parameter  repre¬ 
sents  the  field  name  in  the  associated  database.  It  is  passed  to  the  CGI  scripts 
where  required. 

•  PARAM  NAME=tURL_dbJnput  VALUE  =”  ”  This  parameter  represents  the 
field  name  in  the  associated  database.  It  is  passed  to  the  CGI  scripts  where 
required. 
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•  PARAM  NAME=ExcInd_db_Input  VALUE  =”  ”  This  parameter  represents 
the  field  name  in  the  associated  database.  It  is  passed  to  the  CGI  scripts 
where  required. 

•  PARAM  NAME=Purpose_db_Input  VALUE  =”  ”  This  parameter  represents 
the  field  name  in  the  associated  database.  It  is  passed  to  the  CGI  scripts 
where  required. 

•  PARAM  NAME=Comments_db_Input  VALUE  =”  ”  This  parameter  repre¬ 
sents  the  field  name  in  the  associated  database.  It  is  passed  to  the  CGI  scripts 
where  required. 

•  PARAM  NAME=Vl_Label_Input  VALUE=”  Problem  Area”  This  is  the  label 
that  will  appear  on  the  first  button.  It  is  also  the  string  that  will  be  searched 
for  if  the  button  is  pressed.  It  is  a  parent  term  in  the  first  level  taxonomy  data 
file.  It  should  only  be  changed  if  using  a  taxonomy  other  than  DecisionNet. 

•  PARAM  NAME=V2_Label_Input  VALUE=”  Functional  Area”  This  is  the  la¬ 
bel  that  will  appear  on  the  second  button.  It  is  also  the  string  that  will  be 
searched  for  if  the  button  is  pressed.  It  is  a  parent  term  in  the  first  level 
taxonomy  data  file.  It  should  only  be  changed  if  using  a  taxonomy  other  than 
DecisionNet. 

•  PARAM  NAME=V3_Label_Input  VALUE=”Industry  Type”  This  is  the  label 
that  will  appear  on  the  third  button.  It  is  also  the  string  that  will  be  searched 
for  if  the  button  is  pressed.  It  is  a  parent  term  in  the  first  level  taxonomy  data 
file.  It  should  only  be  changed  if  using  a  taxonomy  other  than  DecisionNet. 

•  PARAM  NAME=V4_LabeLInput  VALUE=”  Organization  Type”  This  is  the 
label  that  will  appear  on  the  fourth  button.  It  is  also  the  string  that  will 
be  searched  for  if  the  button  is  pressed.  It  is  a  parent  term  in  the  first  level 
taxonomy  data  file.  It  should  only  be  changed  if  using  a  taxonomy  other  than 
DecisionNet. 

•  PARAM  NAME=V5_Label_Input  VALUE=”  Solution  Method”  This  is  the  la¬ 
bel  that  will  appear  on  the  fifth  button.  It  is  also  the  string  that  will  be 
searched  for  if  the  button  is  pressed.  It  is  a  parent  term  in  the  first  level 
taxonomy  data  file.  It  should  only  be  changed  if  using  a  taxonomy  other  than 
DecisionNet. 

•  PARAM  NAME=Protocol_Input  VALUE=”http”  This  is  the  default  protocol. 
This  should  not  be  changed. 

•  PARAM  NAME=Data_URL_Input  VALUE=”  131.120.39.60”  This  is  the  URL 
of  the  Java  code  as  well  as  the  taxonomy  data  files.  It  should  be  changed  to 
reflect  to  actual  location  of  those  files. 
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•  PARAM  NAME=DB_URL_Input  VALUE=”  131.120.39.63”  This  is  the  URL 
of  the  DecisionNet  database  and  CGI  scripts.  It  should  be  changed  to  reflect 
to  actual  location  of  those  files. 

•  PARAM  NAME=Tax_Ll_FileLocJnput  VALUE=”/Dnet/Tax_Ll.txt”  This  is 
the  directory  location  and  file  name  of  the  taxonomy  level  1  data  file.  It  is 
relative  to  the  WWW  accessible  root.  These  should  be  changed  to  reflect  a 
new  taxonomy  or  location. 

•  PARAM  NAME=Tax_L2_FileLocJnput  VALUE=”/Dnet/Tax_L2.txt”  This  is 
the  directory  location  and  file  name  of  the  taxonomy  level  2  data  file.  It  is 
relative  to  the  WWW  accessible  root.  These  should  be  changed  to  reflect  a 
new  taxonomy  or  location. 

•  PARAM  NAME=Tax_L3_FileLocJnput  VALUE=”  /Dnet/TaxJL3.txt”  This  is 
the  directory  location  and  file  name  of  the  taxonomy  level  3  data  file.  It  is 
relative  to  the  WWW  accessible  root.  These  should  be  changed  to  reflect  a 
new  taxonomy  or  location. 

•  PARAM  NAME=Tax_L4_FileLoc_Input  VALUE=”/Dnet/Tax_L4.txt”  This  is 

the  directory  location  and  file  name  of  the  taxonomy  level  4  data  file.  It  is 
relative  to  the  WWW  accessible  root.  These  should  be  changed  to  reflect  a 
new  taxonomy  or  location. 

•  PARAM  NAME=Reg_Script_Loc_Input  VALUE= 

”  /cgi-win/dnet/ provider/regteca.exe”  This  is  the  directory  location  and  file 
name  of  the  registration  script.  It  is  relative  to  the  WWW  accessible  root.  It 
should  be  changed  to  reflect  a  new  script  or  location. 

•  PARAM  NAME=Search_Engine_Loc_Input  VALUE=”  ”  This  is  the  directory 
location  and  file  name  of  the  search  algorithm.  It  is  relative  to  the  WWW 
accessible  root.  It  should  be  changed  to  reflect  a  new  script  or  location. 

•  PARAM  NAME=Default_Weight  Jnput  VALUE=”  ”  This  paramater  is  used 
b\  the  search  algorith.  It  should  be  left  at  0.2  to  given  even  weight  to  all  five 
variables.  If  fewer  than  5  variables  were  utilized  then  it  must  be  adjusted. 

•  PARAM  NAME=Default_C_Deg_Input  VALUE=”  ”  This  paramater  is  used 
by  the  search  algorithm.  It  is  set  0.8.  It  can  be  adjusted  if  further  research 
indicates  a  better  default. 

•  PARAM  NAME=Default_P_Deg_Input  VALUE=”  ”  This  paramater  is  used 
b\  the  search  algorithm.  It  is  set  0.4.  It  can  be  adjusted  if  further  research 
indicates  a  better  default. 
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•  PARAM  NAME=Default_SJ)egJnput  VALUE=”  ”  This  paramater  is  used 
by  the  search  algorithm.  It  is  set  0.6.  It  can  be  adjusted  if  further  research 
indicates  a  better  default. 

•  PARAM  NAME=Vl_cgiJabel  Jnput  VALUE=”tProblemArea”  This  parame¬ 
ter  is  specific  to  the  DecisionNet  database.  It  should  be  changed  to  reflect  the 
actual  field  name  of  the  first  variable  of  a  new  database. 

•  PARAM  NAME=V1  _value_default  Jnput  VALUE=”ALL”  Default  value  for 
the  initial  display. 

•  PARAM  NAME=V2_cgiJabel  Jnput  VALUE=”tPunctionalArea”  This  param¬ 
eter  is  specific  to  the  DecisionNet  database.  It  should  be  changed  to  reflect 
the  actual  field  name  of  the  second  variable  of  a  new  database. 

•  PARAM  NAME=V2_value_default  Jnput  VALUE=” ALL”  Default  value  for 
the  initial  display. 

•  PARAM  NAME=V3_cgiJabel  Jnput  VALUE=”tIndType”  This  parameter  is 
specific  to  the  DecisionNet  database.  It  should  be  changed  to  reflect  the  actual 
field  name  of  the  third  variable  of  a  new  database. 

•  PARAM  N AME=V3_value_default  Jnput  VALUE=”ALL”  Default  value  for 
the  initial  display. 

•  PARAM  NAME=V4_cgiJabelJnput  VALUE=”tOrgType”  This  parameter  is 
specific  to  the  DecisionNet  database.  It  should  be  changed  to  reflect  the  actual 
field  name  of  the  fourth  variable  of  a  new  database. 

•  PARAM  NAME=V4_value.default  Jnput  VALUE=”ALL”  Default  value  for 
the  initial  display. 

•  PARAM  NAME=V5_cgiJabel  Jnput  VALUE=”tSolutionMethod”  This 
parameter  is  specific  to  the  DecisionNet  database.  It  should  be  changed  to 
reflect  the  actual  field  name  of  the  fifth  variable  of  a  new  database. 

•  PARAM  N AME= V5 _value_default  Jnput  VALUE=”ALL”  Default  value  for 
the  initial  display. 
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APPENDIX  D.  BROWSER  APPLET 


//  DNET.Browse . j  ava :  Applet 

//  The  DNET_Browse  class  is  the  applet  that  allows  producers  and 
//  consumers  to  view  and  explore  the  full  multi -dimensional  taxonomy 
// 

//  Copyright  by:  LT  Chris  Corgnati  for  Thesis  work  with  Prof  Bhargava 

// 

//  Last  modified:  1300  08  Aug  1997  version  1.1 
/  /  ******************************************************************** 
import  java. applet.*; 
import  java.awt.*; 

public  class  DNET_Browse  extends  Applet  { 

//An  HTML  page  must  feed  the  following  parameters  to  this  applet 
String  title_Param; String  message.Param; 

String  LeftButtonLabel_Param; 

String  ProviderID_Param; String  ConsumerID_Param; 

String  TechID_Param; String  TechName_Param; 

String  tObjectType.Param; 

String  tURL_Param; 

String  ExcInd_Param; 

String  Purpose_Param ; String  Comment s_Param; 

String  ProviderID_db_Param; String  Consumer ID_db_Param; 

String  TechID_db_Param; String  TechName_db_Param; 

String  tObjectType_db_Param; 

String  tURL_db_Param; 

String  ExcInd_db_Param; 

String  Purpose_db_Param; String  Comment s_db_Par am; 

String  Vl_Label_Param; String  V2_Label_Param; 

String  V3_Label_Param; String  V4_Label_Param; 

String  V5_Label_Param; 

String  Protocol_Param; String  Data_URL_Param ; 

String  DB_URL_Param ; int  Port_Param; 

String  Tax_Ll_FileLoc_Param;String  Tax_L2_FileLoc_Param; 


String  Tax_L3_FileLoc_Param; String  Tax_L4_FileLoc_Param; 
String  Reg_Script _Loc_Param ; String  Search_Engine_Loc_Param; 

String  Default_Weight_Param; String  Default_C_Deg_Param; 
String  Default_P_Deg_Param; String  Default _SJDeg_Param; 

String  Vl_cgi_label_Param; String  Vl_value_default_Param; 
String  V2_cgi_label_Param; String  V2_value_default_Param; 
String  V3_cgi_label_Param; String  V3_value_default_Param; 
String  V4_cgi_label_Param; String  V4_value_default_Param; 
String  V5_cgi_label_Param; String  V5_value_def ault_Param; 

/ /  DNET  Class  Constructor 
public  DNET_Browse()  ■{ 

> 

//  APPLET  INFO  SUPPORT: 

public  String  getAppletlnf o() 

{ 

return  "Name:  DNET\r\n"  + 

"Author:  LT  Christopher  M.  Corgnati\r\n"  + 
"Created  with  Microsoft  Visual  J++  Version  1.1"; 


public  void  initO  { 

this . t itle_Param  =  getParameter("title_input") ; 
this.LeftButtonLabel.Param  = 

getParameter ( "Lef tButtonLabel_input " ) ; 
this.ProviderlD.Param  =  getParameter("ProviderID_Input") ; 
this. Consumer ID_Param  =  getParameter ("ConsiunerlD.Input") ; 
this . TechID_Param  —  getParameter ("TechID_Input") ; 
this . TechName_Param  =  getParameter ("TechName.Input ") ; 
this. tObjectType_Param  =  getParameter C "tObject Type_Input ") ; 
this.tURL_Param  =  get Parameter ("tURL_ Input ") ; 
this . ExcInd_Param  =  getParameter ( "ExcInd.Input ") ; 
this.Purpose_Param  =  getParameter ( "Purpose_Input ") ; 
this.Comments_Param  =  getParameter C"Comments_Input ") ; 

this. Provider ID_db_Param  =  getParameter("ProviderID_db_Input") ; 
this .Consumer ID_db_Param  =  getParameter (" Consumer ID_db_ Input") ; 
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this.TechID_db_Param  =  getParameter ("TechID_db_Input") ; 
this .TechName_db_Param  =  getParameter("TechName_db_Input") ; 
this .tObjectType_db_Param  =  getParameter("tObjectType_db_Input") ; 
this . tURL_db_Param  =  getParameter("tURL_db_Input") ; 
this .ExcInd_db_Param  =  getParameter ( "Exclnd_db_lnput ") ; 
this.Purpose_db_Param  =  getParameter("Purpose_db_Input") ; 
this.Comments_db_Param  =  getParameter("Comments_db_Input") ; 

this .Vl_Label_Param  =  getParameter("Vl_Label_Input") ; 
this.V2_Label_Param  =  getParameter("V2_Label_Input") ; 
this.V3_Label_Param  =  getParameter("V3_Label_Input") ; 
this.V4_Label_Param  =  getParameter("V4_Label_ Input") ; 
this.V5_Label_Param  =  getParameter("V5_Label_Input") ; 

this .Protocol_Param  =  getParameter("Protocol_Input") ; 
this.Data_URL_Param  =  getParameter("Data_URL_Input") ; 
this . DB_URL_Param  =  getParameter("DB_URL_Input") ; 

Port_Param  =  80; 

this.Tax_Ll_FileLoc_Param  =  getParameter ("Tax_Ll_FileLoc_Input") ; 
this .Tax_L2_FileLoc_Param  =  getParameter("Tax_L2_FileLoc_Input") ; 
this .Tax_L3_FileLoc_Param  =  getParameter ( "Tax _L3_FileLoc_Input ")  ; 
this.Tax_L4_FileLoc_Param  =  getParameter ("Tax_L4_FileLoc_Input") ; 
this .Reg_Script_Loc_Param  =  getParameter ("Reg_Script_Loc_Input") ; 
this. Sear ch_Engine_Loc_Param  = 

getParameter ( "Search_Engine_Loc_Input " ) ; 
this.Default_Weight_Param  =  getParameter ("Default_Weight_Input") ; 
this .Default _C_Deg_Param  =  getParameter ("Default_C_Deg_Input") ; 
this.Default_P_Deg_Param  =  getParameter ("Default_P_Deg_Input") ; 
this .Default _S_Deg_Param  =  getParameter ("Default_S_Deg_Input") ; 

this . Vl_cgi_label_Param  =  getParameter("Vl_cgi_label_Input") ; 
this.Vl_value_default_Param  = 

getParameter ( " Vl_value_def ault_Input " ) ; 
this.V2_cgi_label_Param  =  getPcirameter("V2_cgi_label_Input") ; 
this.V2_value_default_Param  = 

getParameter ( " V2_value_def ault_Input " ) ; 
this.V3_cgi_label_Param  =  getParameter("V3_cgi_label_Input") ; 
this.V3_value_default_Param  = 

getParameter ( " V3_value_def ault_Input " ) ; 
this . V4_cgi_label_Param  =  getParameter("V4_cgi_label_Input") ; 
this. V4_value  _def  ault  _Par am  = 

getParameter ( " V4_value_def ault.Input " ) ; 
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this . V5_cgi_label_Param  =  getParameter("V5_cgi_label_Input") ; 
this. V5_value_default_Param  = 

getParameter ( V5_value_def ault_Input " ) ; 

//  This  calls  the  Taxonomy  screen.  Message  can  be  changed  here 
Frame  f3  =  new  Frame (); 

Taxonomy  T  =  new  Taxonomy (f 3, t it le.Param, 

"Please  use  this  browser  to  explore  this  multi-variable, 
multi-dimensional  taxonomy.  Use  the  \n" 

+" ’Return’  button  to  cancel  the  applet.  A  double  click  on  an 
item  will  reveal  any  items  below  \n" 

+'it  in  the  Taxonomy.  It  will  also  highlight  your  choice  in 
the  boxer  above  the  lists.  \n" 

+"This  Applet  is  written  in  Java  By  LT  Chris  Corgnati An" , 

Lef tButt onLabel.Param , ProviderID_Param , TechID_Param , 
TechName.Param , tOb j  ectType_Param , tURL.Param , ExcInd.Param , 
Purpose.Param , Comment s.Param , Consumer ID_Par am , Vl_Label_Param , 
V2_Label_Param , V3_Label_Param , V4_Label_Param , V5_Label_Param , 
Protocol_Param , Data_URL_Param , DB_URL_Param , Port.Param , 
Tax_Ll_FileLoc_Param,Tax_L2_FileLoc_Param, 
Tax_L3_FileLoc_Param,Tax_L4_FileLoc_Param , 
Reg_Script_Loc_Param, Search_Engine_Loc_Param, 
Default_Weight_Param,Default_C_Deg_Param,Default_P_Deg_Param, 
Default_S_Deg_Param, 

Vl_cgi_label_Param, Vl_value_default_Param, 

V2_cgi_label_Param , V2_value_def ault _Param , 

V3_cgi_label_Param , V3_value_def ault _Param , 

V4_cgi_label_Param, V4_value_default_Param, 
V5_cgi_label_Param,V5_value_default_Param, 

ConsumerID_db_Param , Provider ID_db_Param , 

TechID_db_Param , TechName_db_Param , tOb j  ectType_db_Param , 
tURL_db_Param , ExcInd_db_Param , Purpose_db_Param , 
Comments_db_Param) ; 

T. resize (700, 700) ; 

T.  showO  ; 

> 

} 
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APPENDIX  E.  REGISTRATION  APPLET 


//  DNET_Reg . j  ava :  Applet 

//  The  DNET_Reg  class  is  the  applet  that  allows  producers  to  register 
//  thier  technologies  with  the  full  multi-dimensional  taxonomy 
// 

//  Copyright  by:  LT  Chris  Corgnati  for  Thesis  work  with  Prof  Bhargava 

// 

//  Last  modified:  1300  08  Aug  1997  version  1.1 
// ******************************************************************** 
import  java. applet.*; 
import  java.awt.*; 

public  class  DNET_Reg  extends  Applet  { 

//An  HTML  page  must  feed  the  following  parameters  to  this  applet 
String  title.Param; String  message.Param; 

String  LeftButtonLabel_Param; 

String  ProviderID_Param; String  Consumer ID_Param; 

String  TechID_Param; String  TechName_Param; 

String  tObjectType.Param; 

String  tURL_Param; 

String  ExcInd_Param; 

String  Purpose_Param; String  Comment s_Param; 

String  Provider ID_db_Param; String  ConsumerID_db_Param; 

String  TechID_db_Param; String  TechName_db_Param; 

String  tObjectType_db_Param; 

String  tURL_db_Param; 

String  ExcInd_db_Param; 

String  Purpose_db_Param; String  Comments_db_Param; 

String  Vl_Label_Param; String  V2_Label_Param; 

String  V3_Label_Param; String  V4_Label_Param ; 

String  V5_Label_Param; 

String  Protocol_Param; String  Data_URL_Param; 

String  DB_URL_Param; int  Port.Param; 

String  Tax_Ll_FileLoc_Param; String  Tax_L2_FileLoc_Param; 
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String  Tax_L3_FileLoc_Param; String  Tax_L4_FileLoc_Param; 
String  Reg_Script_Loc_Param; String  Search_Engine_Loc_Param; 

String  Def ault_Weight_Param; String  Default_C_Deg_Param; 
String  Def ault_P_Deg_Param; String  Default_S_Deg_Param; 

String  Vl_cgi_label_Param ; String  Vl_value_default_Param; 
String  V2_cgi_label_Param; String  V2_value_default_Param; 
String  V3_cgi_label_Param; String  V3_value_default_Param; 
String  V4_cgi_label_Param; String  V4_value_default_Param; 
String  V5_cgi_label_Param; String  V5_value_def ault.Param; 


//  Constructor  Code 

public  DNET_Reg()  { 

} 

//  APPLET  INFO  SUPPORT: 

public  String  getAppletlnf o() 

{ 

return  "Name:  DNET\r\n"  + 

"Author:  LT  Christopher  M.  Corgnati\r\n"  + 
"Created  with  Microsoft  Visual  J++  Version  1.1"; 


public  void  init()  { 

this . t itle_Param  =  getParameter("title_input") ; 
this . LeftButtonLabel_Param  = 

getParameter("LeftButtonLabel_input") ; 
this . Provider ID_Param  =  getParameter("ProviderID_Input") ; 
this .Consumer ID_Param  —  getParameter("ConsumerID_Input") ; 
this . TechID_Param  =  getParameter ("TechID. Input") ; 
this . TechName_Param  =  getParameter ("TechName.Input") ; 
this.tObjectType.Param  =  getParameter ( "tObjectType.Input ") ; 
this . tURL.Param  =  getParameter ("tURL.Input")  ; 
this . ExcInd_Param  =  getParameter ("Exclnd_lnput") ; 
this . Purpose_Param  =  getParameter ("Purpose_Input") ; 
this.Comments.Param  =  getParameter ("Comments_Input") ; 

this.ProviderID_db_Param  =  getParameter ( "ProviderID_db_Input ") ; 
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this . ConsumerID_db_Param  =  getParameter("ConsumerID_db_Input") ; 
this . TechID_db_Param  =  getParameter ("TechID_db_Input ") ; 
this .TechName_db_Param  =  getParameter ("TechName_db_Input") ; 
this .tObjectType_db_Param  =  getParameter ("tObjectType_db_Input") ; 
this . tURL_db_Param  =  getParameter ("tURL_db_Input") ; 
this .ExcInd_db_Param  =  getParameter ("Exclnd_db_lnput") ; 
this.Purpose_db_Param  =  getParameter ( "Purpose_db_Input") ; 
this . Comments_db_Param  =  getParameter ("Comments_db_Input ") ; 

this.Vl_Label_Param  =  getParameter("Vl_Label_Input") ; 
this.V2_Label_Param  =  getParameter("V2_Label_Input") ; 
this.V3_Label_Param  =  getParameter("V3_Label_Input") ; 
this . V4_Label_Param  =  getParameter("V4_Label_ Input") ; 
this.V5_Label_Param  =  getParameter("V5_Label_Input") ; 

this .Protocol_Param  =  getParameter("Protocol_Input") ; 
this . Data_URL_Param  =  getParameter("Data_URL_Input") ; 
this . DB_URL_Param  =  getParameter ( "DB_URL_Input ") ; 

Port_Param  =  80; 

this.Tax_Ll_FileLoc_Param  =  getParameter ( "Tax_Ll_FileLoc_Input ") ; 
this.Tax_L2_FileLoc_Param  =  getParameter ("Tax_L2_FileLoc_Input") ; 
this .Tax_L3_FileLoc_Param  =  getParameter ("Tax_L3_FileLoc_Input") ; 
this .Tax_L4_FileLoc_Param  =  getParameter ("Tax_L4_FileLoc_Input") ; 
this . Reg_Script_Loc_Param  =  getParameter ("Reg_Script_Loc_Input") ; 
this . Search_Engine_Loc_Param  = 

getParameter ("Search_Engine_Loc_Input") ; 
this .Def ault_Weight_Paxam  =  getParameter("Default_Weight_Input") ; 
this .Default _C_Deg_Param  =  getParameter ("Def ault_C_Deg_Input") ; 
this .Def ault_P_Deg_Param  =  getParameter( "Def ault_P_Deg_Input") ; 
this. Def ault_S_Deg_Param  =  getParameter ( "Def ault_S_Deg_Input") ; 

this.Vl_cgi_label_Param  =  getParameter("Vl_cgi_label_Input") ; 
this . Vl_value_def ault_Param  = 

getParameter ( " Vl_value_def ault_Input " ) ; 
this.V2_cgi_label_Param  =  getParameter("V2_cgi_label_Input") ; 
this.V2_value_default_Param  = 

getParameter ( " V2_value_def ault_Input " ) ; 
this . V3_cgi_label_Param  =  getParameter("V3_cgi_label_Input") ; 
this . V3_value_def ault_Param  = 

getParameter ( " V3_value_def ault_Input " ) ; 
this . V4_cgi_label_Param  =  getParameter ("V4_cgi_label_Input") ; 
this . V4_value_def ault_Param  = 
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getParameter ( " V4_value_def ault.Input " ) ; 
this . V5_cgi_label_Param  =  getParameter("V5_cgi_label_Input") ; 
this.V5_value_default_Param  = 

getParameter ( "  V5_value_def ault.Input " ) ; 

//  This  calls  the  Taxonomy  screen.  Message  can  be  changed  here 
Frame  fl  =  new  FrameQ; 


Taxonomy  T  =  new  Taxonomy (f 1 ,title_Param, 

Please  use  this  browser  to  classify  and  register  objects 
within  the  system.  \n" 

+"Use  the  'Submit'  button  to  register  your  object.  Use  the 
'Return'  button  to  cancel  \n" 

+"the  applet.  A  double  click  on  an  item  will  reveal  any  items 
below  it  in  the  Taxonomy.  \n" 

+"It  will  also  highlight  your  choice  in  the  boxes  above  the 
lists.  \n" 

+  This  Applet  is  written  in  Java  By  LT  Chris  Corgnati . \nH , 

LeftButtonLabel_Param)ProviderID_Param,TechID_Param, 

TechName.Param , tOb j  ectType.Param , tURL.Param , ExcInd.Param , 
Purpose.Param , Comment s_Param , ConsumerlD.Param , Vl_Label_Param , 
V2_Label_Param , V3_Label_Param , V4_Label_Param , V5_Label_Param, * 
Prot ocol.Param , Data_URL_Param , DB_URL_Param , Port.Param , 

Tax_ L 1 _Fi leLo  c_Param , Tax_L2_FileLoc_Param , 

Tax_L3_FileLoc_Param , Tax_L4_FileLoc_Param, 

^■eS-Script-Loc_Param,  Search_Engine_Loc_Param, 

Def ault_Weight _Par  am, Default _C_Deg_Par  am, Default _P_Deg_Par am, 
Def  ault_S_Deg__Param , 

v 1 _cgi_label_Param , VI _value_def ault.Param , 

V2-Cgi_label_Param , V2_value  default  Param1 

V3_cgi_label_Param,V3_value_default_Param, 

V4_cgi_label_Param , V4_value_def ault_Param , 
V5_cgi_label_Param,V5_value_default_Param, 

Consumer ID_db_Param , ProviderID_db_Param , 

TechID.db.ParamjTechName.db.ParamjtObjectType.db.Param, 

tURL_db_Param , ExcInd_db_Param , Purpose_db_Param , 
Comments_db_Param) ; 


T . resize (700,700) ; 
T.showO ; 

> 


> 
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APPENDIX  F.  SEARCH  APPLET 


//  DNET_Search. java:  Applet 

//  The  DNET_Search  class  is  the  applet  that  controls  the  inputs  to  the 
//  search  algorithm  and  displays  the  results 
// 

//  Copyright  by:  LT  Chris  Corgnati  for  Thesis  work  with  Prof  Bhargava 

// 

//  Last  modified:  1350  08  Aug  1997  Version  1.1 

/ /******************************************************************** 
import  j  ava . applet . * ; 
import  j  ava . awt . * ; 

public  class  DNET_Search  extends  Applet  { 

//An  HTML  page  must  feed  the  following  parameters  to  this  applet 
String  title.Param; String  message_Param; 

String  LeftButtonLabel_Param; 

String  ProviderID_Param; String  ConsumerID_Param; 

String  TechID.Param; String  TechName_Param; 

String  tObjectType_Param; 

String  tURL_Param; 

String  ExcInd_Param; 

String  Purpose_Param; String  Comments_Param; 

String  Provider ID_db_Param; String  Consumer ID_db_Param; 

String  TechID_db_Param; String  TechName_db_Param; 

String  tObjectType_db_Param; 

String  tURL_db_Param ; 

String  ExcInd_db_Param; 

String  Purpose_db_Param;  String  Cominents_db_Param; 

String  Vl_Label_Param; String  V2_Label_Param; 

String  V3_Label_Param; String  V4_Label_Param; 

String  V5_Label_Param; 

String  Protocol_Param; String  Data_URL_Param; 

String  DB_URL_Param ; int  Port_Param; 

String  Tax_Ll_FileLoc_Param; String  Tax_L2_FileLoc_Param; 
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String  Tax_L3_FileLoc_Param; String  Tax_L4_FileLoc_Param; 
String  Reg_Script_Loc_Param ; String  Search_Engine_Loc_Param; 


String  Default_Weight_Param; String  Def ault_C_Deg_Param; 
String  Def ault_P_Deg_Param; String  Default_S_Deg_Param; 


String 

String 

String 

String 

String 


Vl_cgi_label_Par am; String 
V2_cgi_label_Par am; String 
V3_cgi_label_Param; String 
V4_cgi_label_Param; String 
V5_cgi_label_Param; String 


Vl_value_def ault_Param; 
V2_value_def ault _Param ; 
V3_value_def ault_Param; 
V4_value_def ault_Param ; 
V5_value_def ault_Param; 


//  Constructor  Code 

public  DNET_Search()  { 

> 

//  APPLET  INFO  SUPPORT: 

public  String  getAppletlnf o() 

{ 

return  "Name:  DNET\r\n"  + 

"Author:  LT  Christopher  M.  Corgnati\r\n"  + 

"Created  with  Microsoft  Visual  J++  Version  1  1"- 
>  ’ 

// - 

public  void  initO  { 

this .title_Param  =  getParameter("title_input") ; 
this.LeftButtonLabel.Param  = 

getParameter ( "Lef tButtonLabel.input " ) ; 
this.ProviderlD.Param  =  getParameter ("ProviderlD.Input") ; 
this. Consumer ID_Param  =  getParameter ("ConsumerID_Input") ; 
this . TechID.Param  =  getParameter ("TechID.Input") ; 
this . TechName_Param  =  getParameter("TechName_Input") ; 
this . tObjectType_Param  =  getParameter ( "tObj ectType_Input ") ; 
this. tURL.Param  =  getParameter ("tURL.Input") ; 
this . ExcInd.Param  =  getParameter (" Ex clnd_ Input ")  ; 
this . Purpose_Param  =  getParameter ( "Purpose_Input ") ; 
this . Comments_Param  =  getParameter("Comments_Input") ; 

this . ProviderID_db_Param  =  getParameter ("ProviderID_db_Input") ; 
this. Consumer ID_db_Param  =  getParameter ("ConsumerID_db_Input") ; 
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this .TechID_db_Param  =  getParameter("TechID_db_Input") ; 
this.TechName_db_Param  =  getParameter("TechName_db_Input") ; 
this.tObjectType_db_Param  =  getParameter("tObjectType_db_Input") ; 
this . tURL_db_Param  =  getParameter("tURL_db_Input") ; 
this.ExcInd_db_Param  =  getParameter ("Exclnd_db_lnput") ; 
this .Purpose_db_Param  =  getParameter ("Purpose_db_Input") ; 
this.Comments_db_Param  =  getParameter ("Comments_db_Input") ; 

this.Vl_Label_Param  =  getParameter("Vl_Label_Input") ; 
this.V2_Label_Param  =  getParameter("V2_Label_Input") ; 
this . V3_Label_Param  =  getParameter ("V3_Label_Input") ; 
this.V4_Label_Param  =  getParameter ("V4_Label_Input") ; 
this .  V5_Label_Param  =  getParameter("V5_Label_Input") ; 

this.Protocol_Param  =  getParameter("Protocol_Input") ; 
this . Data_URL_Param  =  getParameter ("Data_URL_Input") ; 
this . DB_URL_Param  =  getParameter ("DB_URL_ Input")  ; 

Port_Param  =  80; 

this.Tax_Ll_FileLoc_Param  =  getParameter ( "Tax _Ll_FileLoc_Input ") ; 
this  .Tax_L2_FileLoc_Param  =  getParameter  ("Tax  _L2_FileLoc_Input") ; 
this.Tax_L3_FileLoc_Param  =  getParameter ("Tax_L3_FileLoc_Input")  ; 
this  .Tax_L4_FileLoc_Param  =  getParameter ( "Tax_L4_FileLoc_Input ")  ; 
this.Reg_Script_Loc_Param  =  getParameter ("Reg_Script_Loc_Input") ; 
this . Search_Engine_Loc_Param  = 

getParameter ( "Search_Engine_Loc_Input ")  ; 
this.  Default  .Weight  _Param  =  getParameter  ("Def  ault_Weight_Input")  ; 
this.Default_C_Deg_Param  =  getParameter ( "Def ault _C_Deg_Input ") ; 
this. Def ault_P_Deg_Param  =  getParameter ("Def ault_P_Deg_ Input") ; 
this. Def ault _S_Deg_Param  =  getParameter ("Def ault_S_Deg_Input") ; 

this.Vl_cgi_label_Param  =  getParameter("Vl_cgi_label_Input") ; 
this.Vl_value_default_Param  = 

getParameter ( " Vl_value_def ault_Input " ) ; 
this.V2_cgi_label_Param  =  getParameter (" V2_cgi_label_Input" ) ; 
this.V2_value_default_Param  = 

getParameter ( " V2_value_def  ault_Input " ) ; 
this.V3_cgi_label_Param  =  getParameter("V3_cgi_label_Input") ; 
this . V3_value_def  ault_Param  = 

getParameter ( " V3_value_def ault.Input " ) ; 
this.V4_cgi_label_Param  =  getParameter("V4_cgi_label_Input") ; 
this . V4_value_def ault_Param  = 

getParameter ( " V4_value_def ault_Input " ) ; 
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this.V5_cgi_label_Param  =  getParameter("V5_cgi_label_Input") ; 
this . V5_value_def ault_Param  = 

getParameter ( " V5_value_def ault_Input " ) ; 

//  This  calls  the  Taxonomy  screen.  Message  can  be  changed  here 
Frame  f2  =  new  Frame (); 

Taxonomy  T  =  new  Taxonomy (f 2 ,title_Param, 

Welcome  to  the  Search  Engine.  Please  use  this  applet  to 
specify  your  preferences  \n" 

+"and  objectives  for  the  search  algorithm.  Press  ’Define 
Search  Weights’  to  move  to  \n" 

+  the  next  screen.  Press  ’Return’  to  cancel  the  applet. 

A  double  click  on  an  item  will  \n" 

+ "reveal  any  items  below  it  in  the  Taxonomy.  It  will  also 
highlight  your  choice  in  the  top  boxes.  \n" 

+"This  Applet  is  written  in  Java  By  LT  Chris  Corgnati.\n" , 

LeftButtonLabel_Param,ProviderID_Param,TechID_Param, 

Te  chName.Par am ,  t  Ob  j  e  ctType_Param ,  tURL_Param ,  ExcInd.Param , 
Purpose_Param , Comment s.Param , ConsumerID_Param , Vl_Label_Param , 
V2_Label_Param , V3_Label_Param , V4_Label_Param , V5_Label_Param , 
Protocol_Param,Data_URL_Param,DB_URL_Param,Port_Param, 
Tax_Ll_FileLoc_Param,Tax_L2_FileLoc_Param, 
Tax_L3_FileLoc_Param,Tax_L4_FileLoc_Param, 
Reg_Script_Loc_Param,Search_Engine_Loc_Param, 
Default_Weight_Param,Default_C_Deg_Param,Default_P_Deg_Param, 

Def  ault_S_Deg_Param, 

V 1 _cgi_label_Param , V 1 _value_def ault_Param , 

V2_cgi_label_Param , V2_value_def ault_Param , 
V3_cgi_label_Param,V3_value_default_Param, 

V4_cgi_label_Param, V4_value_def ault.Param , 

V5_cgi_label_Param , V5_value_def ault_Param , 

Consumer ID_db_Par am , Provider ID_db_Par am , 

Te chID_db_Param,TechName_db_Param , tOb j  ectType_db_Param , 
tURL_db_Param , ExcInd_db_Param , Purpose_db_Param , 
Comments_db_Param) ; 

T . resize (700 , 700) ; 

T. show() ; 

> 

> 
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APPENDIX  G.  TAXONOMY 


//  The  Taxonomy  class  is  the  main  interface  for  all  of  the  Dnet 
//  applets 

//  Copyright  by:  LT  Chris  Corgnati  for  Thesis  work  with 
//  Prof  Bhargava 

//  Last  modified:  Version  1.2 

//  1300  12  Aug  1997 

// - 

import  j  ava . awt . * ; 
import  java.io.*; 
import  j  ava . net . * ; 
import  java. applet . 

public  class  Taxonomy  extends  Frame  { 


//Flags 

that  pass  control  internal  to  this  object 

private 

static 

final 

int 

cancel  =  0; 

private 

static 

final 

int 

submit  =  1; 

private 

static 

final 

int 

search  =  27; 

private 

static 

final 

int 

Vl_button_token  = 

2; 

private 

static 

final 

int 

V2_button_token  = 

3; 

private 

static 

final 

int 

V3_button_token  = 

4; 

private 

static 

final 

int 

V4_button_token  = 

5; 

private 

static 

final 

int 

V5_button_token  = 

6; 

private 

static 

final 

int 

Vl_token  =  7; 

// 

private 

static 

final 

int 

Vl_2D_token  =  8; 

//future 

use 

// 

private 

static 

final 

int 

Vl_3D_token  =  9; 

//future 

use 

// 

private 

static 

final 

int 

Vl_4D_token  =  10;  //future 

use 

private 

static 

final 

int 

V2_token  =  11; 

// 

private 

static 

final 

int 

V2_2D_token  =  12 

//future 

use 

// 

private 

static 

final 

int 

V2_3D_token  =  13 

//future 

use 

// 

private 

static 

final 

int 

V2_4D_token  =  14 

//future 

use 

private 

static 

final 

int 

V3_token  =  15; 

private 

static 

final 

int 

V3_2D_token  =  16 

/ /future 

use 

// 

private 

static 

final 

int 

V3_3D_token  =  17 

//future 

use 

// 

private 

static 

final 

int 

V3_4D_token  =  18 

//future 

use 
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private  static  final  int  V4_token  =  19; 

//  private  static  final  int  V4_2D_token  =  20 
//  private  static  final  int  V4_3D_token  =  21 
//  private  static  final  int  V4_4D_token  =  22 


//future  use 
//future  use 
//future  use 


private  static  final  int  V5_token  =  23; 

private  static  final  int  V5_2D_token  =  24 

private  static  final  int  V5_3D_token  =  25 

private  static  final  int  V5_4D_token  =  26 


/ /  Value  strings  are  set  to  the  parameter  strings  passed  from  HTML 
String  ProviaerID_Value  =  new  String (ProviderID_Param) ; 

String  Consumer ID_Value  =  new  String (Consumer ID_Param) ; 

String  TechID.Value  =  new  String (TechID_Param) ; 

String  TechName_Value  =  new  String (TechName_Param) ; 

String  tObjectType_Value  =  new  String (tObj ectType_Param) ; 

String  tURL.Value  =  new  String (tURL.Param) ; 

String  ExcInd_Value  =  new  String (Exc Ind.Param) ; 

String  Purpose_Value  =  new  String (Purpose_Param) ; 

String  Comments_Value  =  new  String (Comment s_Param) ; 

/ /these  represent  the  database  column  names-passed  from  HTML 
String  Consumer ID_db_value  =  new  String ( Consumer ID_db) ; 

String  Provider ID_db_value  =  new  String (ProviderID_db) ; 

String  TechID_db_value  =  new  String (TechID.db) ; 

String  TechName_db_value  =  new  String (TechName_db)  ; 

String  tObjectType_db_value  =  new  String (tObj ectType_db) ; 

String  tURL_db_value  =  new  String (tURL.db) ; 

String  Exclnd_db_value  =  new  String(ExcInd_db) ; 

String  Purpose_db_value  =  new  String (Purpose_db) ; 

String  Comments_db_value  =  new  String (Comment s_db) ; 

//button  labels 

String  Vl_Label  =  new  String (Vl_Label_Param) ; 

String  V2_Label  =  new  String (V2_Label_Param) ; 

String  V3_Label  =  new  String (V3_Label_Param) ; 

String  V4_Label  =  new  String (V4_Label_Param) ; 

String  V5_Label  =  new  String (V5_Label_Param) ; 

//Networking  variables  and  file  locations 
String  Protocol  =  new  String (Protocol) ; 
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String  Data_File_Home  =  new  String (Data_URL) ; 

String  Database_Home  =  new  String (DB_URL) ; 
int  port  =  Port; 

String  Tax_Ll  =  new  String(Tax.Ll.FileLoc) ; 

String  Tax_L2  =  new  String(Tax_L2_FileLoc) ; 

String  Tax_L3  =  new  String(Tax_L3_FileLoc) ; 

String  Tax_L4  =  new  String(Tax_L4_FileLoc) ; 

String  cgi_regteca  =  new  String (Reg_Script_Loc) ; 

String  Search_Engine_Loc  =  new  String(Search_Engine_Loc) ; 

//default  search  values 

String  Default .Weight  =  new  String (Default _Weight_Param) ; 

String  Default _C_Deg  =  new  String (Default_C_Deg_Param) ; 

String  Def ault_P_Deg  =  new  String (Def ault_P_Deg_Param) ; 

String  Default_S_Deg  =  new  String (Def ault_S_Deg_Param) ; 

// cgi  and  database  names,  and  default  values  for  initial  display 
String  Vl_cgi_label  =  new  String (Vl_cgi_label) ; 

String  Vl.Value  =  new  String (Vl_value_def ault ) ; 

String  V2_cgi_label  =  new  String (V2_cgi_label) ; 

String  V2_Value  =  new  String (V2_value_def ault) ; 

String  V3_cgi_label  =  new  String (V3_cgi_label) ; 

String  V3_Value  =  new  String (V3_value_def ault) ; 

String  V4_cgi_label  =  new  String (V4_cgi_label) ; 

String  V4_Value  =  new  String (V4_value_def ault) ; 

String  V5_cgi_label  =  new  String (V5_cgi_label) ; 

String  V5_Value  =  new  String (V5_value_def ault) ; 

private  int  List.Token;  //shows  the  active  list 

Button  Submit , Cancel , Vl.Button , V2_Button , 

V3_Button , V4_Button , V5_Button ; 

MultiLineLabel  Narrative; 

List  Level. 1 , Level_2 , Level_3 , Level_4 ; 

TextField  Vl_Field,Vl_2D_Field, 

V1.3D .Field , Vl_4D_Field ; 

TextField  V2 .Field, V2_2D_Field, 

V2.3D .Field , V2_4D_Field ; 

TextField  V3_Field, V3_2D_Field, 
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V3_3D_Field , V3_4D_Field ; 

TextField  V4_Field,V4_2D_Field, 

V4_3D_Field , V4_4D_Field ; 

TextField  V5_Field,V5_2D_Field, 

V5_3D_Field , V5_4D_Field ; 

TextField  Current _Field , Message .Field ; 

GridBagLayout  gridbag  =  new  GridBagLayoutO ; 

InputStream  input; 

String  querystring; 

//  value  is  used  to  differentiate  which  applet  is  calling 
String  button.label  =  new  String (Submit.Butt on  Label) • 

// - : _ ; _ 

//  Constuctor  Code-instances  of  taxonomy  must  call  it  with  this  info 

public  Taxonomy (Frame  f, String  title, String  message. 

String  Submit_Button_Label, 

String  ProviderlD.Param, String  TechID.Param, 

String  TechName.Param, String  tObjectType.Param, 

String  tURL.Param, String  ExcInd.Param, String  Purpose.Param, 
String  Comments.Param, String  Consumer ID.Param, 

String  Vl_Label_Param , String  V2  Label  Pa ram t 
String  V3_Label_Param,  String  V4_Label_Param! 

String  V5_Label_Param, String  Protocol, 

String  Data.URL, String  DB.URL , int  Port, String  Tax_Ll_FileLoc, 
String  Tax_L2_FileLoc, String  Tax_L3_FileLoc, 

String  Tax_L4_FileLoc , 

String  Reg_Script_Loc, String  Search.Engine.Loc, 

String  Default_Weight_Par am, String  Default_C_Deg_Param, 
String  Default_P_Deg_Param, String  Def ault_S_Deg_Param, 

String  Vl_cgi_label, String  Vl_value_def ault , 

String  V2_cgi_label, String  V2_value_def ault , 

String  V3_cgi_label, String  V3_value_def ault , 

String  V4_cgi_label, String  V4_value_def ault , 

String  V5_cgi_label, String  V5_value_def ault , 

String  ConsumerlD.db, String  Provider ID_db, 

String  TechID.db, String  TechName.db, String  tObjectType.db, 
String  tURL.db, String  Exclnd.db, String  Purpose.db, 

String  Comments.db)  { 
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super(title) ; 


// - 

//  Panel  1-Buttons 

Cancel  =  new  Button  ("Return  to  DecisionNet") ; 
Submit  =  new  Button  (Submit_Button_Label) ; 

Message.Field  =  new  TextField(30) ; 
Message_Field . setEditable (false) ; 


Panel  pi  =  new  Panel (); 
pi . setLayout (gridbag) ; 


// 

// 


// 

// 


constrain  (pi ,  Submit  ,(>,0,1,1,  GridBagConstraints .  BOTH , 
GridBagConstraint s. CENTER, 0. 0,0. 0, 10, 10, 10, 10)  ; 
constrain  (pi ,  Message.F ield ,  1 , 0 , 1 , 1 ,  GridBagConstraints .  BOTH , 
GridBagConstraints.CENTER,0. 0,0.0, 10, 10, 10, 10) ; 
constrain (pi , Cancel , 2 , 0 , 1 , 1 , GridBagConstraints . BOTH , 
GridBagConstraints . CENTER, 0 .0,0.0,10,10,10, 10) ; 


Panel  2-Instructions 

Narrative  =  new  Mult iLineLabel (message,  1)  ; 

Panel  p2  =  new  Panel  0; 
p2 . setLayout (gridbag) ; 

constrain (p2 , Narrative ,  0 , 0 , 1 , 1 ,  GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 0,0, 0,0); 


Panel  3-Selection  Display 
VI .Button  =  new  Button 
V2_Button  =  new  Button 
V3_Button  =  new  Button 
V4_Button  =  new  Button 
V5_Button  =  new  Button 


(Vl.Label) ; 
(V2_Label) ; 
(V3_Label) ; 
(V4_Label) j 
(V5_Label) ; 


Vl.Field  =  new  TextField(18) ; 
Vl.Field . set Text (Vl.Value) ; 
Vl.Field. setEditable (false) ; 
Vl_2D_Field  =  new  TextField(18) ; 

Vl_2D_Field. setEditable (false) ; 
Vl_3D_Field  =  new  TextField(18) ; 

V1_3D .Field. setEditable(false) ; 
Vl_4D_Field  =  new  TextField(18) ; 
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Vl_4D_Field.setEditable (false) ; 

V2_Field  =  new  TextField(18) ; 
V2_Field . setText (V2_Value) ; 
V2_Field . setEditable (false) ; 
V2_2D_Field  =  new  TextField(18) ; 

V2_2D_Field. setEditable (false) ; 
V2_3D_Field  =  new  TextField(18) ; 

V2_3D_Field. setEditable (false) ; 
V2_4D_Field  =  new  TextField(18) ; 
V2_4D_Field. setEditable (false) ; 

V3_Field  =  new  TextField(18) ; 
V3_Field . setText (V3_Value) ; 
V3_Field . setEditable (false) ; 
V3_2D_Field  =  new  TextField(18) ; 

V3_2D_Field. setEditable (false) ; 
V3_3D_Field  =  new  TextField(18) ; 

V3_3D_Field. setEditable (false) ; 
V3_4D_Field  =  new  TextField(18) ; 
V3_4D_Field. setEditable (false) ; 

V4_Field  =  new  TextField(18) ; 
V4_Field. setText (V4_ Value) ; 
V4_Field . setEditable (false)  ; 
V4_2D_Field  =  new  TextField(18) ; 

V4_2D_Field. setEditable(f alse) ; 
V4_3D_Field  =  new  TextField(18) ; 

V4_3D_Field. setEditable (false) ; 
V4_4D_Field  =  new  TextField(18) ; 
V4_4D_Field. setEditable (false) ; 

V5_Field  =  new  TextField(18) ; 
V5_Field . setText (V5_Value) ; 
V5_Field. setEditable (false) ; 
V5_2D_Field  =  new  TextField(18) ; 

V5_2D_Field. setEditable (false) ; 
V5_3D_Field  =  new  TextField(18) ; 

V5_3D_Field. setEditable (false) ; 
V5_4D_Field  =  new  TextField(18) ; 
V5_4D_Field. setEditable (false) ; 
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Panel  p3  -  new  Panel (); 
p3 . setLayout (gridbag) ; 


constrain (p3 , Vl.Button ,  1 , 0 , 1 , 1 , GridBagConstraint s . HORIZONTAL , 
GridBagConstraints .CENTER, 0.0, 0.0, 1, 1, 1, 1) ; 
constrain  Cp3 , V2_Button ,1,1,1,!, GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0 .0,0. 0,1, 1,1,1); 
constrain (p3 , V3_Butt on , 1 , 2 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0.0, 0.0, 1,1, 1,1); 
constrain (p3 , V4_Butt on , 1 , 3 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0 .0,0. 0,1, 1,1,1); 
constrain (p3 , V5_Butt on , 1 , 4 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints .CENTER, 0.0,0. 0, 1 ,1,1,1); 

constrain (p3 , Vl_Field , 2 , 0 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints .CENTER, 0.0, 0.0, 1, 1, 1, 1) ; 
constrain (p3 , V 1_2D .Field , 3 , 0 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0 .0,0. 0,1, 1,1,1); 
constrain (p3 , V1_3D .Field , 4 , 0 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints .CENTER, 0.0, 0.0, 1, 1 ,1,1); 
constrain (p3 , Vl_4D_Field , 5 , 0 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints  .CENTER, 0.0, 0.0, 1, 1.,  1,1); 

constrain (p3, V2_Field, 2, 1 , 1 , 1 .GridBagConstraints .HORIZONTAL, 
GridBagConstraints .CENTER, 0. 0,0.0, 1, 1, 1,1); 
constrain (p3 , V2_2D_Field , 3 , 1 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 1,1, 1,1); 
constrain (p3 , V2_3D_Field , 4 , 1 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0 .0,0. 0,1, 1,1,1); 
constrain (p3 , V2_4D_Field , 5 , 1 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0.0, 0.0, 1,1, 1,1); 

constrain (p3 , V3_Field , 2 , 2 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0.0, 0.0, 1,1, 1,1); 
constrain (p3 , V3_2D_Field , 3 , 2 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0 .0,0. 0,1, 1,1,1); 
constrain (p3 , V3_3D_Field , 4 , 2 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0 .0,0. 0,1, 1,1,1); 
constrain  Cp3 , V3_4D_Field , 5 , 2 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 1,1, 1,1); 

constrain (p3 , V4.F ield , 2 , 3 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
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GridBagConstraints . CENTER, 0 .0,0. 0,1, 1,1,1); 
constrain (p3 , V4_2D_Field, 3 ,3,1,1, GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0 .0,0. 0,1, 1,1,1); 
constrain (p3 , V4_3D_Field , 4 , 3 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 1,1, 1,1); 
constrain (p3 , V4_4D_F ield , 5 , 3 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 1,1, 1,1); 

constrain (p3 , V5_Field , 2 , 4 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 1,1, 1,1); 
constrain (p3 , V5_2D_F ield, 3, 4, 1,1, GridBagConstraints . HORIZONTAL , 
GridBagConstraints. CENTER, 0.0, 0.0, 1,1, 1,1) ; 
constrain (p3 , V5_3D_Field , 4 , 4 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 1,1, 1,1); 
constrain (p3 , V5_4D_Field , 5 , 4 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 1,1, 1,1); 


/ /  Panel  4-Display  boxes  for  hierarchical  levels 
Current .Field  =  new  TextField(30) ; 

Current.Field . setEditable (false) ; 

Level.l  =  new  List  (12,  false); 

Level_2  =  new  List  (12,  false); 

Level_3  =  new  List  (12,  false); 

Level_4  =  new  List  (12,  false); 

Panel  p4  =  new  Panel (); 
p4 . setLayout (gridbag) ; 

constrain (p4 , Current .Field , 2 , 0 , 2 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints. CENTER, 0.0, 0.0, 1,1, 1,1) ; 

constrain (p4 , Level. 1 , 1 , 1 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0 .0,0. 0,1, 1,1,1); 
constrain (p4 , Level_2 , 2 , 1 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0 .0,0. 0,1, 1,1,1); 
constrain (p4 , Level_3 , 3 , 1 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 1,1, 1,1); 
constrain (p4 , Level_4 , 4 , 1 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0 . 0 , 0 . 0 , 1 , 1 , 1 , 1) ; 

/ /  Add  panels  to  the  top  level  window  and  arrange  the  panels 
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this . setLayout (gridbag) ; 


constrain  (this , pi, 1,0, 1,1, GridBagConstraint s . NONE , 
Gr idBagConstr aints . CENTER ,0.0, 0.0, 1,1, 1,1); 
constrain  (this , p2 , 1 , 1 , 1 , 1 , Gr idBagConstraint s . NONE , 
Gr idBagConstraints . CENTER ,0.0, 0.0, 1,1, 1,1); 
constrain  (this , p3 , 1 , 2 , 1 , 1 , Gr idBagConstraint s . NONE, 
GridBagConstraints . CENTER ,0.0, 0.0, 4, 4, 4, 4); 
constrain  (this,p4, 1,3,1, 1 .GridBagConstraints .NONE, 
GridBagConstraints . CENTER ,0.0, 0.0, 4, 4, 4, 4); 

> 


// 

// 


// 

// 

// 

// 

// 

// 


Event  Handler 

public  boolean  action (Event  event, Object  arg)  { 
if  (event .target  instanceof  Button)  { 
if  (event .target  ==  Submit)  { 

if  (((St ring) event. arg) .equals ("Submit  for  Registration")) 
answer (submit) ; 

else  if  (((String) event. arg) .equals 

("Define  Search  Weights"))  answer (search) ; 
else  if  (((String) event. arg) .equals 

("Return  to  DecisionNet"))  answer (cancel) ; 


> 

else  if  (event . target  ==  Vl.Button) 
else  if  (event . target  ==  V2_Button) 
else  if  (event .target  ==  V3_Button) 
else  if  (event .target  ==  V4_Button) 
else  if  (event .target  ==  V5_Bntton) 
else  answer (cancel) ; 
return  true; 

> 


answer (Vl_button_token) ; 
answer (V2_button_token) ; 
answer (V3_button_token) ; 
answer (V4_button_token) ; 
answer (V5_button_token) ; 


if  (event .target  instanceof  List)  { 

if  ((event. target  ==  Level.l)  &  (List_Token  ==  111)) 
answer (VI .token) ; 

else  if  ( (event .target  ==  Level_2)  &  (List .Token  ==  111)) 
answer (VI _2D_token) ; 

else  if  ( (event .target  ==  Level_3)  &  (List .Token  ==  111)) 
answer(Vl_3D_token) ; 

else  if  ((event. target  ==  Level_4)  &  (List .Token  ==  111)) 
answer(Vl_4D_token) ; 


else  if  ( (event .target  ==  Level.l)  &  (List .Token  ==  222)) 
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// 

// 

// 

// 

// 

// 


// 

// 

// 

// 


// 

// 

// 

// 

// 

// 


answer (V2_token) ; 

else  if  ((event .target  ==  Level_2) 
answer (V2_2D_token) ; 
else  if  ((event. target  ==  Level_3) 
answer (V2_3D_token) ; 
else  if  ((event .target  ==  Level_4) 
answer (V2_4D_token) ; 

else  if  ( (event .target  ==  Level_l) 
answer (V3_token) ; 

else  if  ((event .target  ==  Level_2) 
answer (V3_2D_token) ; 
else  if  ((event .target  ==  Level_3) 
answer (V3_3D_token) ; 
else  if  ((event .target  ==  Level_4) 
answer (V3_4D_token) ; 

else  if  ((event. target  ==  Level_l) 
answer (V4_token) ; 

else  if  ((event .target  ==  Level_2) 
answer (V4_2D_token) ; 
else  if  ((event .target  ==  Level_3) 
answer (V4_3D_token) ; 
else  if  ((event. target  ==  Level_4) 
answer (V4_4D_token) ; 

else  if  ((event. target  ==  Level.l) 
answer (V5_token) ; 

else  if  ((event. target  ==  Level_2) 
answer (V5_2D_token) ; 
else  if  ((event. target  ==  Level_3) 
answer (V5_3D_token) ; 
else  if  ((event. target  ==  Level_4) 
answer (V5_4D_token) ; 


else  answer(99) ; 
return  true; 

> 

else  return  false; 

> 

// - 

protected  void  answer (int  answer)  { 


&  (List_Token  ==  222)) 
&  (List_Token  ==  222)) 
&  (List_Token  ==  222)) 

&  (List_Token  ==  333)) 
&  (List_Token  ==  333)) 
&  (List_Token  ==  333)) 
&  (List_Token  ==  333)) 

&  (List_Token  ==  444)) 
&  (List_Token  ==  444) ) 
&  (List.Token  ==  444)) 
&  (List_Token  ==  444)) 

&  (List .Token  ==  555)) 
&  (List .Token  ==  555)) 
&  (List .Token  ==  555)) 
&  (List.Token  ==  555)) 
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switch(arswer)  { 

case  cancel: cancel.handlerO ; break; 
case  submit : submit_handler() ; break; 
case  search: search_handler() ; break; 

case  Vl.button.token: Vl.button.handlerO ;break; 
case  V2_button_token: V2_button_handler() ; break; 
case  V3_button_token: V3_button_handler() ; break; 
case  V4_button_token: V4_button_handler() ;break; 
case  V5_button_token:V5_button_handler() ; break; 

case  Vl_token: Vl_handler() ;break; 

//  case  Vl_2D_token: Vl_2D_handler() ; break; 

//  case  Vl_3D_token: Vl_3D_handler() ;break; 

//  case  Vl_4D_token: Vl_4D_handler() ;break; 

case  V2_token:V2_handler() ; break; 

//  case  V2_2D_token: V2_2D_handler() ;break; 

//  case  V2_3D_token: V2_3D .handler () ; break; 

//  case  V2_4D_token: V2_4D_handler() ; break; 

case  V3_token:V3_handler() ; break; 
case  V3_2D_token: V3_2D_handler() ; break; 

//  case  V3_3D_token: V3_3D .handler (); break; 

//  case  V3_4D_token: V3_4D_handler() ;break; 

case  V4_token:V4_handler() ; break; 

//  case  V4_2D_token: V4_2D_handler() ; break; 

//  case  V4_3D_token: V4_3D_handler() ;break; 

//  case  V4_4D_token: V4_4D_handler() ;break; 

case  V5_token: V5_handler() ; break; 
case  V5_2D_token: V5_2D_handler() ;break; 
case  V5.3D .token: V5.3D .handler () ;break; 
case  V5_4D_token: V5_4D_handler() ; break; 

> 

} 

// - - - 

protected  void  cancel.handlerO  { 
this. hide () ; 
this. dispose () ; 

> 
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- - 

//used  to  call  the  search  engine 

//The  cgi  script  dictates  that  the  order  be  1,2 ,5 ,3,4 

protected  void  search_handler()  { 

Weights  W  =  new  Weights ("DecisionNet  Search  Engine", 

"Please  use  this  applet  to  specify  your  \n" 

+"preferences  and  objectives  for  the  search  algorithm. \n" 
+"Press  ’Submit  to  Search  Engine’  to  launch  your  search. \n" 
+"This  Applet  is  written  in  Java  By  LT  Chris  Cormati  \n" 

+"  \n" , 

Consumer ID.Value , t Obj  ectType.Value , Vl_Value , V2_Value , 

V5_Value, V3_Value,V4_Value, Protocol, Database.Home, 

port , Sear ch_Engine_Lo c , Def  ault _We ight , Default _C_Deg , 

Def ault_P_Deg , Def ault _S_Deg , ConsumerID_db_ value , 
tOb jectType_db_value , Vl_cgi_label , V2_cgi_label , * 
V3_cgi_label , V4_cgi_label , V5_cgi_label) ; 

W. resize (700, 700) ; 

W. show() ; 

this. hide () ; 
this. dispose () ; 

} 

/ /used  to  call  the  registration  cgi  script 
public  void  submit_handler()  { 

//resets  the  querystring 

String  querystring  =  " 

//These  varibles  need  to  be  passed  in  from  the  HTML  page  to  the  applet 
Querystring  Q  =  new  QueryString (ProviderID_db_value, 

ProviderlD.Value) ; 

Q . add(TechID_db_value,TechID_Value) ; 

Q . add (TechName_db_value , TechName_Value) ; 

Q . add ( t  Ob j  e  ctType_db_ value , t Ob j  e  ct Type .Value ) ; 

//These  variables  are  user  selections 
//The  cgi  script  dictates  that  the  order  be  1,2, 5, 3, 4 
Q.add(Vl_cgi_label,Vl_Value) ; 

Q . add ( V2_cgi_label , V2_Value) ; 

Q . add ( V5_cgi_label , V5_Value) ; 
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Q . add(V3.  cgi.label , V3_Value) ; 

Q.add(V4_cgi_label,V4_Value) ; 

//These  varibles  need  to  be  passed  in  from  the  HTML  page  to  the  applet 
Q . add (tURL_db .value , tURL_Value) ; 

Q. add(ExcInd_db_value,ExcInd_Value) ; 

Q . add (Purpose_db_value , Purpose_Value) ; 

Q . add (Comment s_db_value , Comments_Value) ; 

//sets  local  string  to  return  of  QueryString  method 
querystring  =  Q. query; 

//attempt  to  establish  a  connection 
try  { 

Message_Field.setText("Establishing  a  Network  Connection"); 

URL  u  =  new  URL(Protocol,Database_Home,port,cgi_regteca) ; 

URLConnection  connection  =  u. openConnectionO ; 

connection . setDoOutput (true) ; 

connection . setDoInput (true) ; 

connection. set AllowUserlnteraction (false) ; 

//send  data  to  cgi  program 
DataOutputStream  dos  =  new  DataOutputStream 
(connection. getOutputStreamO) ; 
dos .writeBytes (querystring) ; 
dos.closeO ; 

try  { 

String  thisLine ; 

String  results  =  ("  "); 

DatalnputStream  DIS  =  new  DatalnputStream 
(connection. getlnputStreamO) ; 
while  ((thisLine  =  DIS.readLineO)  !=  null)  { 
results  =  results  +  thisLine; 

> 

DIS. close () ; 

//Open  Dialog  to  display  registration  results 
Frame  f4  =  new  Frame (); 

Reg_Complete  D  =  new  Reg_Complete 

(f4, "DecisionNet  Registration  Results", 
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"Registration  is  Complete.  \n" 

+"Thank  you  for  using  DecisionNet.  \n" 

+"Press  ’ Return ’  to  go  back  to  DecisionNet.  \n" 
+"  \n" 

+"  \n" , 

"Return  to  DecisionNet"); 

D.showO ; 

D . resize (300 , 250) ; 
this. hide () ; 
i’his. dispose () ; 

Message.Field . setText ( "Search  Complete " ) ; 


//catch  any  exceptions 

catch  (MalformedURLException  e)  { 

Message.Field . setText (e . toString () ) ; 

catch  (IOException  e)  { 

Message.Field . setText (e . toString () ) ; 


catch  (NullPointerException  e)  { 

Message_Field .  setText  (e .  toStringO  )  ; 


//catch  any  exceptions 

catch  (MalformedURLException  e)  { 

Message.Field . setText (e . toStringO ) ; 

Frame  f4  =  new  Frame (); 

Reg-Complete  D  =  new  Reg_Complete 

(f 4, "DecisionNet  Registration  Results", 

"Registration  Failed (MalformedURLException) .  \n" 

+"If  this  continues,  please  contact  DecisionNet.  \n" 

+"Press  the  ’Return’  button  to  go  back  to  DecisionNet.  \n" 
4.11 

\n" 

4.  tl 

\n" , 

"Return  to  DecisionNet"); 

D.showO ; 

D. resize (300, 250) ; 
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this. hide (); 
this .dispose () ; 

> 

catch  (IOException  e)  { 

Message_Field. setText (e . toStringO ) ; 

Frame  f4  =  new  FrameO; 

Reg.Complete  D  =  new  Reg_Complete 

(f4, "DecisionNet  Registration  Results", 

"Registration  Failed (IOException) .  \n" 

+"If  this  continues,  please  contact  DecisionNet.  \n" 
+"Press  the  ’Return’  button  to  go  back  to  DecisionNet.  \n" 
+"  \n" 

+"  \n" , 

"Return  to  DecisionNet"); 

D.showO ; 

D.resize(300,250) ; 
this. hide () ; 
this . dispose () ; 

} 

catch  (NullPointerException  e)  { 

Message .Field . setText (e . toStringO ) ; 

Frame  f4  =  new  FrameO; 

Reg.Complete  D  =  new  Reg.Complete 

(f4, "DecisionNet  Registration  Results", 

"Registration  Failed (NullPointerException) .  \n" 

+"If  this  continues,  please  contact  DecisionNet.  \n" 
+"Press  the  ’Return’  button  to  go  back  to  DecisionNet.  \n" 
+"  \n" 

+"  \n" , 

"Return  to  DecisionNet"); 

D.  showO ; 

D . resize (300 , 250) ; 
this. hide () ; 
this .dispose () ; 

} 

} 

// - 

// - 

protected  void  Vl_button_handler  ()  { 

Current .Field . setText (Vl.Label) ; 
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List_Token  =  111; 
button_handler(Vl_Label) ; 


protected  void  Vl.handler  ()  { 

Level_2. clear () ;Level_3. clear (); Level_4. clear () ; 

Vl-Field.  setText  (Level.l  .getSelectedltemO) ; 
Vl_2D_Field.setText(" ") ;Vl_3D_Field. setText (" ") ; 
Vl_4D_Field.setText(" ") ; Vl_Value=Level_l .getSelectedltemO ; 
level_handler (Protocol ,Data_File_Home , Tax_L2 , Level_l , Level_2) ; 


for  future  expansion  to  three  dimensions  of  VI  type  variable 
protected  void  Vl_2D_handler  ()  { 

Level_3. clear () ;Level_4. clear () ; 

Vl_2D_Field . setText (Level_2 . getSelectedltem ( ) ) ; 

Vl_3D_Field . setText ( " " ) ; Vl_4D_Field . setText ( " " ) ; 
Vl_Value=Level_2.  getSelectedltemO ; 

level.handler (Protocol ,Data_File_Home , Tax_L3 , Level_l , Level_2) ; 


for  future  expansion  to  four  dimensions  of  VI  type  variable 
protected  void  Vl_3D_handler  ()  { 

Level_4. clear () ; 

Vl_3D_Field. setText (Level_3. getSelectedltemO ) ; 

Vl_4D_Field. setText (" ") ; 

Vl_Value=Level_3. getSelectedltemO  ; 

level_handler (Protocol , Data_File_Home , Tax_L4 , Level_l , Level_2) ; 


for  future  expansion  to  four  dimensions  of  VI  type  variable 
protected  void  Vl_4D_handler  ()  { 

Vl_4D_Field . setText (Level_4 . getSelectedltem () ) ; 

V 1 _Value=Level_4 . getSelectedltem ( ) ; 

> 


protected  void  V2_button_handler  ()  { 
Current .Field . setText (V2_Label) ; 
List.Token  =  222; 
button_handler(V2_Label) ; 

> 
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// 


protected  void  V2_handler  ()  { 

Level_2. clearC) ;Level_3. clear() ;Level_4. clear() ; 

V2_Field.  setText(Level_l  .getSelectedltemO) ; 

V2_2D_Field . setText ( " " ) ; V2_3D_Field . set Text ( " " ) ; 

V2_4D_Field. setText (" ")  ; V2_Value=Level_l  .getSelectedltemO  ; 

//  level_handler (Protocol , Data_File_Home , Tax_L2 , Level. 1 , Level_2) ; 

} 

// - 

//  for  future  expansion  to  three  dimensions  of  V2  area  variable 
//  protected  void  V2_2D .handler  ()  { 

//  Level_3. clear () ;Level_4. clear () ; 

/ /  V2_2D_Field . setText (Level_2 . getSelectedltemO  ) ; 

//  V2_3D_Field . setText V2_4D_Field . setText ( " " )  ; 

//  tV2Area_Value=Level_2 .getSelectedltemO ; 

//  level.handler (Protocol ,Data_File_Home , Tax_L3 , Level.l , Level_2) ; 

//  > 

// - 

//  for  future  expansion  to  four  dimensions  of  V2  area  variable 
//  protected  void  V2_3D_handler  ()  { 

//  Level_4. clear () ; 

//  V2.3D .Field. setText (Level_3. getSelectedltemO)  ; 

//  V2_4D_Field. setText (""); 

//  tV2Area_Value=Level_3 .getSelectedltemO ; 

/ /  level.handler (Protocol ,Data_File_Home , Tax_L4 , Level.l , Level_2) ; 

//  > 

// - 

//  for  future  expansion  to  four  dimensions  of  V2  area  variable 
//  protected  void  V2_4D_handler  ()  { 

//  V2_4D_Field.setText(Level_4. getSelectedltemO) ; 

//  tV2Area_Value=Level_4. getSelectedltemO ; 

//  > 

// - 

// - 

protected  void  V3_button_handler  ()  { 

Current .Field . setText (V3_Label) ; 

List .Token  =  333; 
button .handler (V3_Label) ; 

> 

// - 

// - 

protected  void  V3_handler  ()  { 
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(Level_2.  clearO)  ;Level_3. clear ()  ;Level_4.clear() ; 

V3_Field .  setText  (Level.l .  getSelectedltemO ) ; 

V3_2D_Field . setText ( " ") ; V3_3D_Field . setText ('"•); 

V3_4D_Field .  setText  ('"■);  V3_Value=Level_l . getSelectedltemO  ; 
level.handler (Protocol ,Data_File_Home , Tax_L2 , Level.l , Level_2) ; 

// - - - - - 

//  for  future  expansion  to  three  dimensions  of  V3  type  variable 
protected  void  V3_2D_handler  ()  { 

Level_3.  clearO  ;Level_4.  clearO  ; 

V3_2D_Field. setText (Level_2. getSelectedltemO) ; 

V3_3D_Field . setText ( " " ) ; V3_4D_Field . setText ( " " ) ; 
V3_Value=Level_2 . getSelectedltem () ; 

level.handler (Protocol , Data_File_Home , Tax_L3 , Level_2 , Level_3) ; 

// - 

//  for  future  expansion  to  four  dimensions  of  V3  type  variable 
//  protected  void  V3_3D_handler  ()  { 

Level_4.  clearO ; 

V3_3D_Field . setText (Level_3 . getSelectedltem () ) ; 

V3_4D_Field. setText ( " ") ;V3_Value=Level_3. getSelectedltemO ; 
level_handler (Protocol , Data_File_Home , Tax_L4 , Level_3 , Level_4) ; 


//  for  future  expansion  to  four  dimensions  of  V3  type  variable 
//  protected  void  V3_4D_handler  ()  { 

/ /  V3_4D_Field. setText (Level_4. getSelectedltemO)  ; 

//  V3_Value=Level_4. getSelectedltemO ; 

//  > 

- - 

// - - 

protected  void  V4_button_handler  ()  { 

Current .Field . setText (V4_Label) ; 

List .Token  =  444; 
button.handler (V4_Label) ; 

} 

- - 

protected  void  V4_handler  ()  { 

(Level_2.  clearO ) ; Level_3.  clearO  ; Level_4.  clearO  ; 

V4_Field. setText (Level.l. getSelectedltemO )  ; 

V4_2D_Field . setText ( " " ) ; V4_3D_Field . setText ( " " ) ; 
V4_4D_Field. set Text (" ") ; V4_Value=Level_l .getSelectedltemO ; 


// 

// 

// 

// 

//  > 
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level_handler (Protocol , Dat a_File_Home , Tax_L2 , Level_l , Level_2) ; 

> 

// - 

//  protected  void  V4_2D_handler  ()  { 

//  Level_3. clear () ;Level_4. clear () ; 

//  V4_2D_Field.setText(Level_2.getSelectedItem()) ; 

//  V4_3D_Field . setText ( " " ) ; V4_4D_Field . setText ( " " ) ; 

//  V4_Value=Level_2.getSelectedItem() ; 

//  level.handler (Protocol , Dat a_File_Home , Tax_L3 , Level_2 , Level_3) ; 

//  > 

// - - 

//  for  future  expansion  to  four  dimensions  of  V4  type  variable 
//  protected  void  V4_3D_handler  ()  { 

//  Level_4. clear () ; 

//  V4_3D_Field.setText(Level_3.getSelectedItem()) ; 

//  V4_4D_Field. setText ("") ;V4_Value=Level_3.getSelectedItem() ; 

//  level_handler (Protocol , Data_File_Home , Tax_L4 , Level_3 , Level_4) ; 

//  > 

// - 

//  for  future  expansion  to  four  dimensions  of  V4  type  variable 
//  protected  void  V4_4D_handler  ()  { 

//  V4_4D_Field. setText (Level_4.getSelectedItem()) ; 

//  V4_Value=Level_4.getSelectedItem() ; 

//  > 

// - 

// - - - 

protected  void  V5_button_handler  ()  { 

Current_Field . setText ( V5_Label) ; 

List .Token  =  555; 
button_handler(V5_Label) ; 

> 

// - 

protected  void  V5_handler  ()  { 

(Level_2. clear ()) ; (Level_3. clear ()) ; (Level_4. clear () ) ; 
V5_Field.  setText (Level.l  .getSelectedltemO)  ; 

V5_2D_Field . setText ( " " ) ; V5_3D_Field . setText ( " " ) ; 

V5_4D_Field . setText ( " " ) ; 

V5_Value=Level_l  .getSelectedltemO ; 

level.handler (Protocol , Dat a_File_Home ,Tax_L2 , Level.l , Level_2) ; 

> 

n - 

protected  void  V5_2D_handler  ()  { 


81 


(Level_3. clear ()) ; (Level_4. clear ()) ; 

V5_2D_Field . setText (Level_2 . getSelect edit em ( ) ) ; 

V5_3D_Field . setText ( " " ) ; V5_4D_Field . setText ( " " ) ; 
V5_Value=Level_2 .  getSelectedltemO ; 

level.handler (Protocol , Data_File_Home , Tax_L3 , Level_2 , Level_3) ; 

// - - - 

protected  void  V5_3D_handler  ()  { 

(Level_4. clear () ) ; 

V5_3D_Field. setText (Level_3. getSelectedltemO ) ; 

V5_4D_Field .  setText  ( 11 " ) ;  V5_Value=Level_3 . get SelectedI tern ()  \ 
level_handler(Protocol,Data_File_Home,Tax_L4, Level  3  Level  4) • 
>  "  ’ 

- - 

protected  void  V5_4D_handler  ()  { 

V5-4D-Field. setText (Level_4. getSelectedltemO ) ; 
V5_Value=Level_4 .  getSelectedltemO ; 

> 

- - 

- - 

protected  void  button_handler  (String  var_name)  { 

Level_l . clear () ;Level_2. clear () ; 

Level_3. clear () ;Level_4. clear () ; 
try  { 

URL  url  =  new  URL (Protocol, Data_File_Home, Tax_Ll ) ; 
URLConnection  connection  =  url.openConnectionO ; 
input  =  connection. getlnputStreamO  ; 

Grep  g  =  new  Grep(var_name,Level_l, input) ; 

catch  (Malf ormedURLException  e)  { 

Current.Field. setText ("URL  Exception") ; 

catch  (IOException  i)  { 

Current.Field. setText ("I/O  Exception") ; 

> 

- - 

protected  void  level_handler (String  Protocol, 

String  Data_File_Home, String  FileLocation, 

List  Current, List  Target)  { 
try  { 

URL  url  —  new  URL (Protocol, Data_File_Home , FileLocation) ; 
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URLConnection  connection  =  url.openConnectionO ; 
input  =  connection. getlnputStreamO  ; 

Grep  g  =  new  Grep (Current .getSelectedltemO .Target , input) ; 

> 

catch.  (MalformedURLException  e)  { 

Current _Field.setText( "URL  Exception") ; 

} 

catch  (IOException  i)  { 

Current _Field.setText(" I/O  Exception") ; 

> 

} 

// - 

// - - - 

//These  constrain  functions  are  used  to  layout  the  components  both 
//within  thier  panels  and  the  panels  within  the  frame. 

//(from  Java  in  Nutshell) 

public  void  constrain  (Container  container , Component  component, 
int  grid..x,int  grid_y,int  grid_width,int  grid_height, 
int  fill, int  anchor, double  weight _x, double  weight_y, 
int  top, int  left, int  bottom, int  right)  { 

GridBagConstraints  c  =  new  GridBagConstraintsO ; 

c.gridx  =  grid.x; c.gridy  =  grid.y; 

c.gridwidth  =  grid_width;c.gridheight  =  grid_height; 

c.fill  =  f ill; c. anchor  =  anchor; 

c.weightx  =  weight _x;c. weighty  =  weight _y; 

if (top  +  bottom  +  left  +  right  >  0) 

c. insets  =  new  Insets (top, left .bottom, right) ; 
((GridBagLayout) container. getLayoutO) .  setConstraints 
(component ,c) ; 
container .  add  (component)  ; 

> 

// - 

public  void  constrain  (Container  container, Component  component, 
int  grid_x,int  grid_y,int  grid_width, int  grid_height)  { 
constrain  (container, component ,grid_x,grid_y,grid_width, 
gr id.height , GridBagConstraints . NONE , 

GridBagConstraints . NORTHWEST ,0.0, 0.0, 0,0, 0,0); 

> 

// - 

public  void  constrain  (Container  container, Component  component, 
int  grid_x,int  grid_y,int  grid_width,int  grid.height, 
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int  top, int  left,int  bottom, int  right)  { 

constrain  ( container , component , grid_x , grid.y , grid.width , 

grid.height , GridBagConstraints . NONE, 

GridBagConstraints .  NORTHWEST ,  0 . 0 , 0 . 0 ,  top ,  left ,  bottom ,  right )  ; 
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APPENDIX  H.  WEIGHTS 


//  The  Weights  class  is  the  interface  for  both  consumer  search  and 
//  producer  registration 
// 

//  Copyright  by:  LT  Chris  Corgnati  for  Thesis  work  with  Prof  Bhargava 
//'’’’ 

//  Last  modified:  Version  1.1 

//  1300  29  July  1997 

// - 

import  j  ava . awt . * ; 
import  java.io.*; 
import  java.net.*; 

public  class  Weights  extends  Frame  { 

//Flags  that  pass  control  internal  to  this  object 
Button  Search, Cancel; 

Label  Problem_Label  ,Functional_Label ,  Organization_Label , 

Industry_Label , Solut ion_Label , Weight_Col , Child_Col , 
Parent.Col , Sibling_Col ; 

MultiLineLabel  Narrative , Legend ; 

TextField  Problem_We ight , Problem_C_Deg , 

Problem_P_Deg , Problem_S_Deg ; 

TextField  Functional_Weight ,Functional_C_Deg, 

Functional_P_Deg,Functional_S_Deg; 

TextField  Organization_Weight,Organization_C_Deg, 

Organizat ion_P_Deg , Organizat ion_S_Deg ; 

TextField  Industry .Weight , Industry_C_Deg, 

Industry_P_Deg, Industry_S_Deg; 

TextField  Solution.Weight , Solut ion_C_Deg, 

Solution_P_Deg,Solution_S_Deg; 

TextField  Message.Field; 

String  Default .Weight  =  new  String (Def ault.Weight.Param) ; 

String  Default.C.Deg  =  new  String (Def ault.C.Deg.Param)  ; 

String  Default.P.Deg  =  new  String (Def ault .P.Deg.Param) ; 
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String  Default_S_Deg  =  new  String(Def ault_S_Deg_Param) ; 

GridBagLayout  gridbag  =  new  GridBagLayout () ; 

/ /Variables  used  to  create  the  querystring 

String  ConsumerlD  =  new  String (ConsumerlD.db) ; 

String  tObjectType  =  new  String (t Ob j ectType.db) ; 

String  tProblemArea  =  new  String (tProblemArea_db) ; 

String  tFunctionalArea  =  new  String (tFunctionalArea_db) ; 

String  tSolutionMethod  =  new  String (tSolutionMethod_db) ; 

String  tlndType  =  new  String (tlndType.db) ; 

String  tOrgType  =  new  String (tOrgType_db) ; 

//Variables  passed  from  taxonomy  object-will  be  submitted  to  search 

String  Consumer ID_Value  =  new  String (Consumer ID_Param) ; 

String  tObjectType_Value  =  new  String (tObj ectType_Param) ; 

String  t Pr oblemAr e a_V alue  =  new  String (tProblemArea.Param) ; 

String  tFunctionalArea.Value  =  new  String (tFunctionalArea_Param) ; 

String  tSo lut i onMe thod_V alue  =  new  String (tSolutionMethod.Param) ; 

String  tlndType _ Value  =  new  String (t IndType_Param) ; 

String  tOrgType.Value  =  new  String (tOrgType_Param) ; 

//Network  variables  to  connect  to  CGI  programs 

String  Protocol  =  new  String (Protocol) ; 

String  dnetl  =  new  String (DB_URL) ; 

int  port  =  Port; 

//  cgi_indexed  is  the  home  of  the  delphi  search  engine  script 

^  String  cgi.indexed  =  new  String(Search_Engine_Loc) ; 

//  Constuctor  Code-instances  of  taxonomy  must  call  it  with  this  info 
public  Weights (String  title, String  message, String  Consumer ID.Param, 
String  tObjectType_Param, String  tProblemArea_Param, 

String  tFunctionalArea_Param, String  tSolutionMethod_Param, 
String  tIndType_Param, String  tOrgType_Param, String  Protocol, 
String  DB_URL , int  Port, String  Search_Engine_Loc, 

String  Def ault .Weight _Param, String  Def ault_C_Deg_Param, 

String  Def ault_P_Deg_Param, String  Def ault_S_Deg_Param, 

String  ConsumerID_db, String  tObjectType.db, 

String  tProblemArea.db, String  tFunctionalArea.db, 

String  tSolutionMethod.db, String  tlndType.db, 

String  tOrgType_db)  { 
super(title) ; 
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// - 

//  Panel  1-Instructions 

Search  =  new  Button  ("Submit  to  Search  Engine"); 

Cancel  =  new  Button  ("  Return  to  DecisionNet  "); 

Message_Field  =  new  TextField(30) ; 

Message_Field . setEditable (false) ; 

Panel  pi  =  new  Panel (); 
pi . setLayout (gridbag) ; 

constrain (pi , Search ,  0 , 0 , 1 , 1 , GridBagConstraints . BOTH , 
GridBagConstraints . CENTER, 0. 0,0. 0, 1 ,1,1,1); 
constrain (pi , Message_Field , 1 , 0 , 1 , 1 , GridBagConstraints . BOTH , 
GridBagConstraints. CENTER, 0.0,0. 0, 1, 1 ,1,1); 
constrain (pi , Cancel , 2 , 0 , 1 , 1 , GridBagConstraints . BOTH , 
GridBagConstraints . CENTER, 0 .0,0. 0,1, 1,1,1); 

// - - 

//  Panel  2-Instructions 

Narrative  =  new  Mult iLineLabel (message, 1) ; 

Panel  p2  =  new  Panel (); 
p2 . setLayout (gridbag) ; 

constrain (p2 , Narrative , 0 , 0 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0 .0,0. 0,0, 0,0,0); 

// - 

//  Panel  3-Instructions 

Legend  =  new  Mult iLineLabel 

("VW  =  Variable  Weight  (must  sum  to  1.0)  \n" 

+  "  \n" 

+"CDM  =  Child  Degradation  Multiplier  \n" 

+"PDM  =  Parent  Degradation  Multiplier  \n" 

+"SDM  =  Sibling  Degradation  Multiplier  \n" 

+"  \n" 

+"Default  Values  are  shown.  Advanced  users  may  define  \n" 
+"custom  values  here.  Degradation  Multipliers  must  be  in  \n" 
+"the  interval  [0,1].  Higher  values  indicate  a  stronger 
preference  \n" 

+"for  the  selected  item  only.  Lower  values  allow  the  search 
to  \n" 

+"return  more  possible  answers  which  may  have  a  lower 
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relevancy. " , 1) ; 


Panel  p3  =  new  Panel (); 
p3 . setLayout (grldbag) ; 

constrain (p3 , Legend , 0 , 0 , 1 , 1 , GridBagConstraint s . HORIZONTAL , 
GridBagConstraints. CENTER, 0.0, 0.0,0, 0,0,0) ; 

// - - - 

//  Panel  3-Selection  Display 

Weight.Col  =  new  LabelO'VW"); 

Child.Col  =  new  Label ( "CDM") ; 

Parent_Col  =  new  Label ( "PDM" ) ; 

Sibling_Col  =  new  LabelC'SDM") ; 

Problem_Label  =  new  Label ("Problem  Area"); 

Funct ional.Label  =  new  Label ("Functional  Area"); 

Industry.Label  =  new  Label ("Industry  Type"); 

0rganization_Label  =  new  Label ("Organization  Type"); 
Solution_Label  =  new  Label ("Solution  Area"); 

Problem_Weight  =  new  TextField(Def ault.Weight ,5) ; 

Problem_Weight . setEditable(true) ; 

Problem.C.Deg  =  new  TextField(Default_C_Deg,5); 

Problem.C.Deg. setEditable (true) ; 

Problem_P_Deg  =  new  TextField (Default _P_Deg, 5) ; 

Problem_P_Deg. setEditable(true) ; 

Problem_S_Deg  =  new  TextField (Def ault_S_Deg, 5) ; 

Problem_S_Deg . setEditable (true)  ; 

Fun ctional_Wei ght  =  new  TextField(Def ault .Weight ,5) ; 

Funct ional.Weight . setEditable (true) ; 

Functional.C.Deg  =  new  TextField (Def ault.C.Deg, 5) ; 

Funct ional.C.Deg . setEditable (true) ; 

Funct ional.P.Deg  =  new  TextField (Def ault.P.Deg, 5) ; 

Funct ional.P.Deg . setEditable (true) ; 

Funct ional.S.Deg  =  new  TextField(Default_S_Deg,5) ; 

Funct ional.S.Deg . setEditable (true)  ; 

Industry .Weight  =  new  TextField (Def ault.Weight, 5) ; 

Industry.Weight . setEditable (true) ; 

Industry.C.Deg  =  new  TextField(Def ault.C.Deg, 5) ; 
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Industry_C_Deg . setEditable (true) ; 

Industry_P_Deg  =  new  TextField(Default_P_Deg,5) ; 

Industry_P_Deg. setEditable (true) ; 

Industry_S_Deg  =  new  TextField(Def ault_S_Deg,5) ; 

Industry_S_Deg. setEditable (true) ; 

Organization_Weight  =  new  TextField (Default .Weight, 5) ; 

Organizat ion.Weight . setEditable (true) ; 

Organization_C_Deg  =  new  TextField(Def ault_C_Deg,5) ; 

Organization_C_Deg. setEditable (true) ; 

Organization_P_Deg  =  new  TextField(Default_P_Deg,5) ; 

Organizat ion_P_Deg . setEditable (true) ; 

Organization_S_Deg  =  new  TextField(Default_S_Deg,5) ; 

Organizat ion_S_Deg. setEditable (true) ; 

Solut ion.Weight  =  new  TextField(Def ault.Weight ,5) ; 

Solut ion.Weight . setEditable (true) ; 

Solution_C_Deg  =  new  TextField(Default_C_Deg,5) ; 

Solution_C_Deg . setEditable (true) ; 

Solution_P_Deg  =  new  TextField(Def ault_P_Deg,5) ; 

Solution_P_Deg. setEditable (true) ; 

Solution_S_Deg  =  new  TextField(Def ault_S_Deg,5) ; 

Solution_S_Deg . setEditable (true) ; 

Panel  p5  =  new  Panel  0; 
p5 . setLayout (gridbag) ; 

constrain(p5 , Weight _Col , 1 , 0 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints. CENTER, 0.0, 0.0,1, 1,1,1); 
constrain (p5 , Child.Col , 2 , 0 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints.CENTER,0.0,0.0,l, 1,1,1); 
constrain(p5 , Parent _Col , 3 , 0 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints .CENTER, 0. 0,0. 0, 1, 1,1,1); 
constrain(p5 , Sibling.Col , 4 , 0 , 1 , 1 , GridBagConstraints . HORIZONTAL , 

Gr idBagConstr aint  s . CENTER ,0.0, 0.0, 1,1, 1,1); 

constrain (p5 , Problem.Label , 0 , 1 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0 .0,0. 0,1, 1,1,1); 
constrain (p5 , Functional .Label , 0 , 2 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints. CENTER, 0.0, 0.0,1, 1,1, 1) ; 
constrain (p5 , Industry.Label , 0 , 3 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 1,1, 1,1); 
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constrain (p5 , Organizat ion.Label ,  0 , 4 , 1 , 1 , 

GridBagConstraints . HORIZONTAL , GridBagConstraints . CENTER 
0.0,0. 0,1, 1,1,1); 

constrain (p5 , Solut ion_Label , 0 , 5 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER, 0 .0,0. 0,1, 1,1,1); 
constrain (p5 , Problem_Weight ,1,1,1, 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 1,1, 1,1); 
constrain (p5 , Problem_C_Deg , 2 , 1 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 1,1, 1,1); 
constrain (p5 , Problem_P_Deg , 3 , 1 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraint s . CENTER ,0.0, 0.0, 1,1, 1,1); 
constrain (p5 , Problem_S_Deg , 4 , 1 , 1 , 1 , GridBagConstraints . HORIZONTAL 
GridBagConstraints . CENTER  „ 0.0, 0.0, 1,1, 1,1); 

constrain(p5 , Functional .Weight , 1 , 2 , 1 , 1 , 

GridBagConstraints . HORIZONTAL , GridBagConstraints . CENTER 
0.0, 0.0, 1,1, 1,1); 

constrain (p5 , Funct ional_C_Deg , 2 , 2 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints. CENTER, 0.0, 0.0, 1,1, 1,1) ; 
constrain (p5 , Funct ional_P_Deg , 3 , 2 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints .CENTER, 0. 0,0. 0, 1, 1, 1, 1) ; 
constrain (p5 , Funct ional_S_Deg , 4 , 2 , 1 , 1 , GridBagConstraints . HORIZONTAL 
GridBagConstraints . CENTER, 0 . 0,0. 0,1, 1,1,1)  ; 

constrain (p5 , Industry.We ight , 1 , 3 , 1 , 1 , GridBagConstraints . HORIZONTAL 
GridBagConstraint  s . CENTER ,0.0, 0.0, 1,1, 1,1); 
constrain (p5 , Indust ry_C_Deg , 2 , 3 , 1 , 1 , GridBagConstraints . HORIZONTAL 

GridBagConstraints. CENTER, 0.0, 0.0, 1, 1, 1, 1) ; 
constrain (p5 , Industry_P_Deg , 3 , 3 , 1 , 1 , GridBagConstraints . HORIZONTAL 
GridBagConstraint  s . CENTER ,0.0, 0.0, 1,1, 1,1); 
constrain (p5 , Industry_S_Deg , 4 , 3 , 1 , 1 , GridBagConstraints . HORIZONTAL , 

Gr idBagConstraint s . CENTER , 0 . 0 , 0 . 0 , 1 , 1 , 1 , 1) ; 

constrain(p5,0rganization_Weight, 1,4, 1, 1, 

GridBagConstraints . HORIZONTAL , GridBagConstraints  CENTER 
0.0, 0.0, 1,1, 1,1); 

constrain(p5,0rganization_C_Deg,2,4, 1, 1, 

GridBagConstraints . HORIZONTAL , GridBagConstraints . CENTER 
0.0, 0.0, 1,1, 1,1); 

constrain (p5 , Organization_P_Deg, 3, 4 ,1,1, 

GridBagConstraints . HORIZONTAL , GridBagConstraints  CENTER 
0.0, 0.0, 1,1, 1,1); 
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constrain(p5 , Organization_S_Deg ,  4 , 4 , 1 , 1 , 

GridBagConstraints . HORIZONTAL , GridBagConstraints . CENTER, 

0.0,0. 0,1, 1,1,1); 

constrain(p5 , Solut ion_Weight , 1 , 5 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints. CENTER, 0.0, 0.0, 1,1,1, 1) ; 
constrain(p5, Solution_C_Deg, 2, 5, 1, 1, GridBagConstraints .HORIZONTAL, 
GridBagConstraints . CENTER, 0 .0,0. 0,1, 1,1,1); 
constrain(p5 , Solut ion_P_Deg , 3, 5 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
Gr idBagConst raint s . CENTER ,0.0, 0.0, 1,1, 1,1); 
constrain(p5 , Solution_S_Deg, 4 ,5,1,1, GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 1,1, 1,1); 


//  Add  panels  to  the  top  level  window  and  arrange  the  panels 
this . setLayout (gridbag) ; 

constrain  (this , pi, 0,0, 1,1, GridBagConstraints . NONE , 
GridBagConstraints . CENTER, 0.0, 0.0, 1,1, 1,1); 
constrain  ( this , p2 , 0 , 1 , 1 , 1 , GridBagConstraints . NONE , 
GridBagConstraints . CENTER, 0 .0,0. 0,1, 1,1,1); 
constrain  (this , p3 , 0 , 2 , 1 , 1 , GridBagConstraints . NONE , 
GridBagConstraints . CENTER ,0.0, 0.0, 4, 4, 4, 4); 
constrain  (this , p5 , 0 , 4 , 1 , 1 , GridBagConstraints . NONE , 
GridBagConstraints . CENTER ,0.0, 0.0, 4, 4, 4, 4); 

} 

// - 

public  boolean  action (Event  event, Object  arg)  { 
if  (event .target  instanceof  Button)  { 
if  (event .target  ==  Cancel)  { 
this. hide (); 
this . dispose () ; 

> 

if  (event .target  ==  Search)  { 

//resets  the  querystring 
String  querystring  =  "  " ; 

//These  varibles  need  to  be  passed  in  from  the  HTML 
//page  to  the  applet 

QueryString  Q  =  new  QueryString (ConsumerlD, 

Consumer ID_Value) ; 

Q . add(tObjectType,tObjectType_Value) ; 
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//These  variables  are  user  selections 
Q . add(tProblemArea,tProblemArea_Value) ; 

Q . add(tFunctionalArea,tFunctionalArea_Value) ; 

Q . add(tSolutionMethod,tSolutionMethod_Value) ; 

Q. add CtIndType,tIndType_ Value) ; 

Q . add(tOrgType,tOrgType_Value) ; 

String  PW  =  new  String(Problem_Weight.getText()) ; 
Q.add("Problem_Weight",PW) ; 

String  PCD  =  new  String (Problem_C_Deg. getText ()) ; 
Q.add("Problem_C_Deg" ,PCD) ; 

String  PPD  =  new  String (Problem_P_Deg. getText ()) ; 
Q.add("Problem_P_Deg",PPD) ; 

String  PSD  =  new  String(Problem_S_Deg. getText () ) ; 

Q . add  C "Problem_S_Deg" , PSD) ; 

String  FW  =  new  String (Functional_Weight . getText ()) ; 

Q . add ( "Funct ional_Weight " , FW) ; 

String  FCD  =  new  String(Functional_C_Deg. getText 0 ) ; 

Q. add ( "Funct ional_C_Deg" , FCD) ; 

String  FPD  =  new  String(Functional_P_Deg. getText ()) ; 

Q . add ( "Funct ional_P_Deg" , FPD) ; 

String  FSD  =  new  String(Functional_S_Deg. getText ()) ; 

Q. add ( "Funct ional_S_Deg" ,FSD) ; 

String  IW  =  new  String (Indus try .Weight .getText ()) ; 

Q . add ( " Industry .Weight " , IW) ; 

String  ICD  =  new  String (Industry_C_Deg. getText ()) ; 
Q.add("Industry_C_Deg",ICD) ; 

String  IPD  =  new  String ( Indus try_P_Deg. getText ()) ; 

Q . add (" Indust ry_P_Deg" , IPD) ; 

String  ISD  =  new  String (Industry_S_Deg. getText ()) ; 

Q. add (" Indust ry_S_Deg ", ISD) ; 

String  OW  =  new  String (Organization_Weight .getText ()) ; 
Q . add ( "Orgauizat ion_Weight " , OW) ; 

String  OCD  =  new  String (Organization_C_Deg. getText () ) ; 
Q.add("Organization_C_Deg" ,OCD) ; 

String  OPD  =  new  String(Organization_P_Deg. getText ()) ; 
Q • add ( "Organization_P_Deg" , OPD) ; 

String  OSD  =  new  String(Organization_S_Deg. getText ()) ; 
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Q . add("Organization_S_Deg" ,OSD) ; 

String  SW  =  new  String (Solution_Weight.getTextO) ; 

Q .add("Solution_Weight" ,SW) ; 

String  SCD  =  new  String(Solution_C_Deg.getTextO) ; 

Q . add ( "Solut ion_C_Deg" , SCD) ; 

String  SPD  =  new  String (Solution_P_Deg.getTextO) ; 

Q. add ( "Solut ion_P_Deg" ,SPD) ; 

String  SSD  =  new  String(Solution_S_Deg.getText()) ; 

Q. add ( "Solut ion_S_Deg",SSD) ; 

//sets  local  string  to  return  of  QueryString  method 
querystring  =  Q. query; 

//attempt  to  establish  a  connection 
try  { 

Message_F ield . setText ( "Establishing  Network 
Connection. 

URL  u  =  new  URL (Protocol.dnetl, port ,cgi_indexed) ; 
URLConnection  connection  =  u. openConnectionO ; 
Message.Field. setText ("Searching  DecisionNet. . ; 
connection. setDoOutput (true) ; 
connection . setDoInput (true) ; 
connection. setAllowUserlnteraction(false) ; 

//send  data  to  cgi  program 
DdtaOutputStream  dos  =  new  DataOutputStream 
(connection. getOutputStreamO ) ; 
dos. writeBytes (querystring) ; 
dos.  closeO ; 

//read  in  CGI  response  (string  of  text) 
try  -C 

String  thisLine; 

String  results  =  ("  "); 

DatalnputStream  DIS  =  new  DatalnputStream 
(connection. getlnputStreamO)  ; 

while  ((thisLine  =  DIS.readLineO)  !=  null)  { 
results  =  results  +  thisLine; 

> 
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DIS. closeO ; 

Message_Field . setText ( "Search  Complete") ; 

//call  results  display  screen  which  will  parse  the 
//input  stream  and  show  it 
Frame  f4  =  new  Frame (); 

Search.Results  S  =  new  Search_Results 
(f4, "DecisionNet  Search  Results", 

"Results  of  your  search.  \n" 

+"Thank  you  for  using  DecisionNet.  \n" 

+ "Press  the  ’Return’  button  to  go  back  to 
DecisionNet.  \n" 


"Return  to  DecisionNet" , results) ; 

S.showO ; 

S.resize(700,700) ; 
this. hide () ; 
this. dispose () ; 

> 

//catch  any  exceptions 

catch  (Malf ormedURLException  e)  { 

Message_Field. setText(e.toStringO) ; 

catch  (IOException  e)  { 

Message_Field.  setText  (e.toStringO); 

> 

catch  (NullPointerException  e)  { 

Message.Field . setText (e . toString () ) • 

> 

> 

//catch  any  exceptions 

catch  (Malf ormedURLException  e)  { 

Message.Field . setText (e . toStringO ) ; 

Frame  f4  =  new  Frame (); 

Reg.Complete  D  =  new  Reg.Complete 
(f 4, "DecisionNet  Search  Results", 

"Search  Engine  Failed(Malf ormedURLException) .  \n" 
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+"If  this  continues,  please  contact  DecisionNet.  \n" 
+ "Press  the  ’Return’  button  to  go  back  to 
DecisionNet.  \n" 

+"  \n" 

+"  \n", 

"Return  to  DecisionNet"); 

D.showO ; 

D. resize (300, 250) ; 
this. hide () ; 
this. dispose () ; 

J 


catch  (IOException  e)  { 

Message_Field.setText("Connection  Failed") ; 

Frame  f4  =  new  FrameO; 

Reg_Complete  D  =  new  Reg_Complete 
(f4, "DecisionNet  Search  Results", 

"Search  Engine  Failed(IOException) .  \n" 

+"If  this  continues,  please  contact  DecisionNet.  \n" 
+"Press  the  ’Return’  button  to  go  back  to 
DecisionNet .  \n" 

+"  \n" 

+”  \n" , 

"Return  to  DecisionNet"); 

D.showO ; 

D . resize (300 , 250) ; 
this,  hide  0; 
this. dispose () ; 

> 

catch  (NullPointerException  e)  { 

Message_Field .  setText  (e .  toStringO  )  ; 

Frame  f4  =  new  FrameO; 

Reg_Complete  D  =  new  Reg_Complete 
(f4, "DecisionNet  Search  Results", 

"Search  Engine  Failed(NullPointerException) .  \n" 

+"If  this  continues,  please  contact  DecisionNet.  \n" 
+"Press  the  ’Return’  button  to  go  back  to 
DecisionNet.  \n" 

+"  \n" 

+"  \n" , 

"Return  to  DecisionNet"); 
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D.showO ; 

D. resize (300, 250) ; 
this .hide () ; 
this. dispose () ; 

> 

> 

return  true; 

> 

else  return  false; 

> 

- - 

//These  constrain  functions  are  used  to  layout  the  components  both 
//within  thier  panels  and  the  panels  within  the  frame. 

//(from  Java  in  Nutshell) 

public  void  constrain  (Container  container, Component  component, 
int  grid_x,int  grid_y,int  grid_width, int  grid_height, 
int  fill, int  anchor , double  we ight_x, double  weight_y, 
int  top, int  left, int  bottom, int  right)  { 

Gr idBagConstr aint s  c  =  new  GridBagConstraintsO  ; 

c.gridx  =  grid_x;c.gridy  =  grid_y; 

c.gridwidth  =  grid_width; c .gridheight  =  grid_height; 

c .fill  =  f ill ; c . anchor  =  anchor; 

c.weightx  =  weight _x; c .weighty  =  weight _y; 

if (top  +  bottom  +  left  +  right  >  0) 

c. insets  =  new  Insets(top, left, bottom, r ight ) ; 

( (GridBagLayout) container . getLayout ( ) ) . setConstraints 
(component, c) ; 
container . add (component) ; 

> 

- - 

public  void  constrain  (Container  container, Component  component, 
int  grid_x,int  grid_y,int  gr id.width , int  grid.height)  { 
constrain  (container , component , grid_x , gr id_y , grid_width , 
grid_height , GridBagConstraints . NONE, 

GridBagConstraints . NORTHWEST, 0 .0,0. 0,0, 0,0,0); 

- - 

public  void  constrain  (Container  container, Component  component, 
int  grid_x, int  grid_y,int  grid.width, int  grid.height, 
int  top, int  left, int  bottom, int  right)  { 
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constrain  (container , component , grid_x , grid_y , gr id_width , 
grid.height , GridBagConstraints . NONE, 

Gr idBagConstraint s . NORTHWEST ,0.0, 0.0, top, left , bottom , right) ; 

> 

> 
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APPENDIX  I.  SEARCH  RESULTS 


//  The  Search  Results  class  is  used  to  display  the  data  returned  from 
//  the  cgi  script  search  engine 
// 

//  Copyright  by:  LT  Chris  Corgnati  for  Thesis  work  with  Prof  Bhargava 

// 

//  Last  modified:  1400  29  July  1997  Version  1.0 

// - - - 

// - 

import  java.awt.*; 
import  java.io.*; 
import  java. util.*; 

public  class  Search_Results  extends  Dialog  { 

//  Control  variables  are  internal  to  this  object 
private  static  final  int  Cancel  =  1; 

protected  Button  cancel; 

protected  MultiLineLabel  label; 

protected  TextArea  display; 

protected  String  line; 
protected  String []  lines; 

protected  int  num_lines; 

GridBagLayout  gridbag  =  new  GridBagLayout () ; 

//  Constructor  code 

public  Search_Results (Frame  f. String  title .String  message. 

String  Cancel_label, String  results) 

super(f , "DecisionNet" .false) ; 

this . setLayout (new  BorderLayout (40 , 60) ) ; 

// - 

//  Creation  and  layout  of  GUI  components 
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Panel  pi  =  new  Panel (); 

pi . setLayout (gridbag) ; 

label  =  new  MultiLineLabel (message, 1) ; 

constrain (pi , label , 0 , 0 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 4, 4, 4, 4); 

Panel  p2  =  new  Panel (); 
p2 . setLayout (gridbag) ; 
display  =  new  TextArea(23,70) ; 

//this  code  parses  the  input  stream  by  the  character  & 

/ / into  an  array  of  strings  to  be  displayed 

StringTokenizer  t  =  new  StringTokenizer (results, "&") ; 
num_linec<  =  t  .countTokensO  ; 
lines  =  new  String [num_lines] ; 
for(int  i  =  0;i  <  num.lines; i++) 
lines [i]  =  (t . next Token ()+"  \n"); 
for(int  i  =  0;i  <  num.lines; i++) display . appendText (lines [i] ) ; 

constrain (p2 , display , 0 , 0 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints. CENTER, 0.0, 0.0, 4, 4, 4, 4) ; 

Panel  p3  =  new  Panel (); 
p3 . setLayout (gridbag) ; 
cancel=new  Button  (Cancel.label) ; 

constrain (p3 , cancel , 0 , 0 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 4, 4, 4, 4); 

this. show () ; 

// - - 

//  Arrange  the  panels 
this . setLayout (gridbag) ; 

//  Add  panels  to  the  top  level  window 
constrain  (this, pi, 1,0, 1, 1, GridBagConstraints. BOTH, 
GridBagConstraints . CENTER, 0 .0,0. 0,3, 3, 3, 3); 
constrain  (this , p2 , 1 , 1 , 1 , 1 , GridBagConstraints . HORIZONTAL , 
GridBagConstraints . CENTER ,0.0, 0.0, 3, 3, 3, 3); 
constrain  (this, p3, 1,2, 1,1, GridBagConstraints. HORIZONTAL, 

GridBagConstraints. CENTER, 0.0, 0.0, 3, 3, 3, 3) ; 
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// 


//  Event  Handler 

public  boolean  action (Event  e, Object  arg)  { 
if  (e. target  instanceof  Button)  { 
answer (Cancel) ; 
return  true; 

> 

else  return  false; 

} 

// - 

protected  void  answer (int  answer)  { 
switch(answer)  { 

case  Cancel: cancel () ; break; 

> 

> 

// - 

protected  void  cancel ()  { 
this. hide () ; 
this. dispose () ; 

> 

// - 

//These  constrain  functions  are  used  to  layout  the  components  both 
//within  thier  panels  and  the  panels  within  the  frame. 

//(from  Java  in  Nutshell) 

public  void  constrain  (Container  container, Component  component, 
int  grid_x,int  grid_y,int  grid.width , int  grid.height, 
int  fill, int  anchor, double  we ight_x, double  weight _y, 
int  top, int  left, int  bottom, int  right)  { 

GridBagConstraints  c  =  new  GridBagConstraintsO ; 

c.gridx  =  grid_x;c.gridy  =  grid_y; 

c.gridwidth  =  grid.width; c.gridheight  =  grid.height; 

c.fill  =  fill ;c.  anchor  =  anchor; 

c.weightx  =  weight _x ; c. weighty  =  weight_y; 

if (top  +  bottom  +  left  +  right  >  0) 

c. insets  =  new  Insets(top, left .bottom, right) ; 

( (GridBagLayout) container . getLayout ( ) ) . setConstraints 
(component, c) ; 
container . add (component) ; 

> 

// - 

public  void  constrain  (Container  container, Component  component. 


101 


int  grid_x,int  grid_y,int  grid_width, int  grid_height)  { 


constrain  ( container , component , grid.x , grid_y , gr id_width , 
grid.height , GridBagConstraints . NONE, 

GridBagConstraints . NORTHWEST ,0.0, 0.0, 0,0, 0,0); 


public  void  constrain  (Container  container, Component  component, 
int  grid_x,int  grid_y,int  grid_width, int  grid_height, 
int  top, int  left, int  bottom, int  right)  { 

constrain  (container, component, grid_x,grid_y,grid_width, 
grid_height , GridBagConstraints . NONE , 

GridBagConstraints . NORTHWEST , 0 . 0 , 0 . 0 , top , left , bottom , right) ; 


APPENDIX  J.  REG  COMPLETE 


//  The  Reg.Complete  class  is  an  class  to  display  registration  results 

// 

//  Copyright  by:  LT  Chris  Corgnati  for  Thesis  work  with  Prof  Bhargava 

// 

//  Last  modified:  1700  9  July  1997  Version  1.0 

// - 

// - 

import  java.awt.*; 

public  class  Reg.Complete  extends  Dialog  { 

//  Control  variables  are  internal  to  this  object 
private  static  final  int  Cancel  =  1; 

protected  Button  cancel; 

protected  MultiLineLabel  label; 

GridBagLayout  gridbag  =  new  GridBagLayout () ; 

//  Constructor  code 

public  Reg_Complete (Frame  f, String  title, String  message. 

String  Cancel_label) 

super (f , "DecisionNet" .false) ; 

this . setLayout (new  BorderLayout (20 , 20) ) ; 

// - 

//  Creation  and  layout  of  GUI  components 
Panel  pi  =  new  Panel (); 

pl.add(label  =  new  MultiLineLabel (message, 1)) ; 

Panel  p2  =  new  Panel  0; 
p2 . setLayout (gridbag) ; 

cancel=new  Button  (Cancel_label) ; 

constrain (p2 , cancel , 1 , 2 , 1 , 1 , GridBagConstraints . HORIZONTAL , 

Gr idBagConstraint s . CENTER ,0.0, 0.0, 4, 4, 4, 4); 
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this . show() ; 

- - 

//  Arrange  the  panels 

this . setLayout (gridbag) ; 

/ /  Add  panels  to  the  top  level  window 

constrain  (this, pi, 1,0, 1, 1 .GridBagConstraints. BOTH, 

Gr idBagConstraint s . CENTER ,0.0, 0.0, 3, 3, 3, 3); 
constrain  (this , p2 , 1 , 1 , 1 , 1 , GridBagConstraints . HORIZONTAL , 

GridBagConstraints. CENTER, 0.0, 0.0, 3, 3,3,3) ; 

- - 

//  Event  Handler 

public  boolean  action  (Event  e,  Object  arg)  { 
if  (e. target  instanceof  Button)  { 
answer (Cancel) ; 
return  true; 

> 

else  return  false; 

> 

// - - - - - 

protected  void  answer (int  answer)  { 
switch (answer)  { 

case  Cancel : cancel () ;break; 

} 

} 

- - 

protected  void  cancel ()  { 
this. hide () ; 
this.disposeO ; 

> 

- - 

public  void  constrain  (Container  container, Component  component, 
int  grid_x,int  grid_y,int  grid_width, int  grid_height, 
int  fill, int  anchor, double  we ight_x, double  weight _y, 
int  top, int  left, int  bottom, int  right)  { 

GridBagConstraints  c  =  new  GridBagConstraints () ; 

c.gridx  =  grid_x;c.gridy  =  grid.y; 

c . gridwidth  =  grid.width; c .gridheight  =  grid.height; 

c-^iH  =  f  ill ;  c .  anchor  =  anchor; 

c.weightx  =  weight _x;c. weighty  =  weight_y; 

if (top  +  bottom  +  left  +  right  >  0) 
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c. insets  =  new  Insets (top, left, bottom, right ) ; 

( (GridBagLayout) container. getLayoutO )  . 

setConstraints( component, c) ; 
container,  add (component) ; 

> 

// - 

public  void  constrain  (Container  container, Component  component, 
int  grid_x,int  grid_y,int  gr i d_ width, int  grid.height)  { 

constrain  (container , component , gr id_x , gr id_y , gr id_width , 
grid_height , GridBagConstraints . NONE, 

GridBagConstraints . NORTHWEST ,0.0, 0.0, 0,0, 0,0); 

> 

// - 

public  void  constrain  (Container  container, Component  component, 
int  grid_x,int  grid_y,int  grid.width, int  grid.height, 
int  top, int  left, int  bottom, int  right)  { 

constrain  (container , component , grid_x , gr id_y , grid_width , 
grid_height, GridBagConstraints. NONE, 

GridBagConstraints .  NORTHWEST , 0 . 0 , 0 . 0 , top ,  left , bottom , right)  ; 

> 

> 
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APPENDIX  K.  GREP 


//  The  Grep  class  is  an  class  to  identify  lines  from  taxonomy. db 
//  that  contain  a  given  string  arguement 
// 

//  Copyright  by:  LT  Chris  Corgnati  for  Thesis  work  with  Prof  Bhargava 

// 

//  Last  modified:  1300  29  July  1997  Version  1.1 

// - - 

import  java.io.*; 
import  java.awt.*; 

public  class  Grep  { 

List  level; 

public  Grep(String  args,List  level, InputStream  i)  { 
try  { 

DatalnputStream  d  =  new  DatalnputStream(i) ; 

GrepInputStream  g  =  new  GrepInputStream(d, args, level) ; 
String  line  =  null; 

String  display  =  null; 

do  { 

//calls  GrepInputStream 
line  =  g.readLineO  ; 

//names  in  data  files  start  at  character  38 
display  =  line . substring (38) ; 

//display  only  values  of  the  attribute  in 
//appropriate  list 
level . addltem (display) ; 

> 

while  (line  !=  null); 
g.  closeO  ; 

> 

catch  (IOException  e)  { 

level . addltem ("unexpected  error") ; 
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} 


> 


> 


finally  { 

> 
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APPENDIX  L.  GREPINPUTSTREAM 


//  The  GrepInputStream  class  is  an  object  to  filter  the  taxonomy 

// 

//  Copyright  by:  LT  Chris  Corgnati  for  Thesis  work  with  Prof  Bhargava 

// 

//  Last  modified:  1300  29  July  1997  Version  1.1 

// - 

import  java.io.*; 
import  java.awt.*; 

public  class  GrepInputStream  extends  FilterlnputStream  { 

String  substring; 

DatalnputStream  in; 

List  level; 

public  GrepInputStream(DataInputStream  in, String  substring, 

List  level){ 
super (in) ; 
this. in  =  in; 

this . substring  =  substring; 

> 

// - - - - 

public  final  String  readLineO  throws  IOException  { 

String  line; 
do  { 

line  =  in. readLineO  ; 

> 

while  ((line  !=  null)  &&  line . indexOf (substring)  ==  -1); 
return  line; 

> 

> 
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APPENDIX  M.  QUERYSTRING 


//  The  QueryString  class  is  an  class  to  combine  string  values  for 
//  input  to  a  CGI  script. 

// 

//  Copyright  by:  LT  Chris  Corgnati  for  Thesis  work  with  Prof  Bhargava 

// 

//  Last  modified:  1400  30  June  1997  Version  1.0 

// - - - - - 

import  j  ava . net . URLEncoder ; 

public  class  QueryString  { 

String  query; 

public  QueryString (Object  name .Object  value)  { 

query  =  URLEncoder.  encode  (name.  toStringO)  +  + 

URLEncoder . encode (value . toString ( ) ) ; 

> 

public  void  add (Object  name, Object  value)  { 

query  +=  +  URLEncoder.  encode  (name.  toStringO)  +  "="  + 

URLEncoder . encode (value . toString ( ) ) ; 

} 

public  String  toStringO  { 
return  query ; 

> 
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APPENDIX  N.  MULTILINELABEL 


//  The  MultiLineLabel  class  is  an  object  to  parse  a  long  string  into 
//  smaller  strings  for  display.  Java  doesn't  support  a  label  greater 
//  than  one  line.  Borrowed  from  "Java  in  a  Nutshell". 

// 

//  Copyright  by:  LT  Chris  Corgnati  for  Thesis  work  with  Prof  Bhargava 

// 

//  Last  modified:  1300  29  July  1997  Version  1.1 

// - 

import  j  ava . awt . * ; 
import  java. util.*; 

public  class  MultiLineLabel  extends  Canvas  { 
public  static  final  int  LEFT=0; 
public  static  final  int  CENTER=1; 
public  static  final  int  RIGHT=2 ; 
protected  String []  lines; 
protected  int  num_lines; 
protected  int  margin_width ; 
protected  int  margin_height ; 
protected  int  line_height; 
protected  int  line_ascent; 
protected  int []  line_widths; 
protected  int  max.width; 
protected  int  alignment=LEFT; 

protected  void  newLabel (String  label)  { 

StringTokenizer  t=new  StringTokenizer (label, "\n") ; 

num_lines  =  t .  countTokensO  ; 

lines  =  new  String [num_lines] ; 

line_widths  =  new  int [num_lines] ; 

f or ( int  i=0 ; i<num_lines ; i++) lines [i] =t . nextTokenO ; 

> 

protected  void  measure ()  { 

FontMetncs  fm  =  this  .getFontMetrics  (this  .getFontO ) ; 
if(fm  ==  null)  return; 

line_height  =  fm. getHeight () ; 
line_ascent  =  fm.getAscentO ; 
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max_width  =  0; 

for (int  i=0; i<num_lines; i++)  { 

line_widths [i]  =  fm. stringWidth(lines [i] ) ; 
if  (line.widths [i]  >max_width)max_width=line_widths [i]  ; 


public  MultiLineLabel (String  label, int  margin.width , 
int  margin_height , int  alignment)  { 

newLabel (label) ; 

this . margin_width  =  margin_width ; 
this.margin_height  =  margin.height ; 
this. alignment  =  alignment; 

> 

public  MultiLineLabel (String  label, int  margin_width , 
int  margin.height)  { 

this  (label,  margin_width,margin_height,  LEFT) ; 

public  MultiLineLabel (String  label, int  alignment)  { 
this  (label,  20, 20,  alignment)  ; 

> 

public  MultiLineLabel (String  label)  { 
this (label ,20,20, LEFT)  ; 


public  void  setLabel (String  label)  { 
newLabel (label) ; 
measure () ; 
repaint () ; 

> 

public  void  setFont(Font  f)  { 
super. setFont(f) ; 
measure () ; 
repaint (); 

> 

public  void  setForeground(Color  c)  { 
super. setForeground(c) ; 
repaint () ; 

> 

public  void  set Alignment (int  a)  {alignment=a; repaint () ;> 

public  void  setMarginWidth(int  mw)  {margin_width=mw ; repaint () ;} 
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public  void  setMarginHeightCint  mh)  {margin_height=mh ; repaint () ;} 
public  int  getAlignmentO  {return  alignment;} 
public  int  getMarginWidthO  {return  margin_width; } 
public  int  getMarginHeightO  {return  margin_height;} 

public  void  addNotifyO  {super. addNotifyO  ;measure() ;} 

public  Dimension  preferredSizeO  { 

return  new  Dimension (max_width  +  2*margin_width, 
num_lines  *  line_height  +  2*margin_height) ; 

} 

public  Dimension  minimumSizeO  { 

return  new  Dimension (max_width,num_lines*line .height) ; 

} 

public  void  ^.aint  (Graphics  g)  { 
int  x,y; 

Dimension  d=this.size() ; 

y=line_ascent  +  (d. height  -  num_lines  *  line_height)/2; 
for  (int  i  =  0;i  <  num_lines; i++,y  +=  line_height)  { 
switch (alignment)  { 
case  LEFT : 

x=margin_width ; break ; 
case  CENTER: 
default : 

x=(d. width  -  line_widths [i] )  /  2; break; 
case  RIGHT: 

x=d. width  -  margin_width  -  line_widths [i] ; break; 

} 

g. drawstring (lines [i] ,x,y); 

} 

} 

} 
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APPENDIX  O.  INDEXED  SEARCH 


unit  Indexedl;  {Technology  Search  Engine;  created  by  Chris  Corgnati. 
Last  updated  23  Jul  97.3- 

interface 

uses 

SysUtils,  WinTypes,  WinProcs,  Messages,  Classes,  Graphics,  Controls, 
Forms,  Dialogs,  DB,  Cgidb,  Cgi,  DBTables; 

type 

TForml  =  class (TForm) 

CGIEnvDatal:  TCGIEnvData; 

BatchMovel:  TBatchMove; 

Table 1:  TTable; 

Query 1 :  TQuery; 

DataSourcel :  TDataSource ; 

BatchMove2:  TBatchMove; 

Table3:  TTable; 

DataSource2:  TDataSource; 

Query2 :  TQuery ; 

Table2 :  TTable; 

Query3:  TQuery; 

DataSource3:  TDataSource; 

Query4 :  TQuery ; 

Table4 :  TTable; 

DataSource4:  TDataSource; 

Table5:  TTable; 

BatchMove3:  TBatchMove; 

BatchMove4:  TBatchMove; 

Table6:  TTable; 

BatchMove5:  TBatchMove; 

Table7 :  TTable; 

Table8 :  TTable; 

procedure  FormCreate (Sender:  TObject); 
private 

{  Private  declarations  } 
public 

{  Public  declarations  } 
end; 
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var 

Forml:  TForml; 
implementation 
{$R  *.DFM} 


procedure  TForml . FormCreate (Sender :  TObject); 


var 

N_R  :  smallint;  {Number  of  Records  in  Technolo.db} 

N-T_R  :  smallint;  {Number  of  Records  in  Search_Temp_2 . db> 

{User  selections  passed  to  cgi  from  applet} 

Var.Value  :  array  [0..4]  of  string; 

{database  field  names} 

Category  :  array  [0..4]  of  string; 

{strings  read  from  applet} 

Temp_Deg_V alue  :  array  [0..4.0..2]  of  string; 

{strings  converted  to  float (single)} 

Deg.Value  :  array  [0..4.0..2]  of  Single; 

{Values  of  variables  from  temp  records} 
temp  :  array  [0.. 50,0.. 4]  of  string; 

{holds  provider  info  for  display} 
info  :  array  [0.. 50,0.. 2]  of  string; 

{Record  Variable  Score} 

R-V-S  :  array  [0. .50,0. .4]  of  Single; 

{Total  Score  for  a  given  record} 

T_S  :  array [0.. 50]  of  Single; 


{strings  read  from  applet} 
Temp.Weight  :  array  [0. .4]  of  string; 
{strings  converted  to  float (single)} 
Weight  :  array  [0..4]  of  Single; 


v  :  smallint; 
r  :  smallint; 
f  :  smallint; 


{variable  counter} 
{record  counter} 
{field  counter} 
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j  :  smallint;  {loop  counter} 
i  :  smallint; 
k  :  smallint; 

C  :  string; 

P  :  string; 

P_Temp  :  string; 

C_2_Temp  :  string; 

P_2_Temp  :  string ; 

{control  flag  for  ’all’  selections} 

Var_All_Bool  :  array  [0.. 50,0.. 4]  of  Boolean; 
{control  flag  for  exact  variable  matches} 
Match.Bool  :  array  [0.. 50,0.. 4]  of  Boolean; 
{control  flag  for  child  in  taxonomy} 
child  :  array  [0.. 50,0.. 4]  of  Boolean; 

{control  flag  for  second  level  child  in  taxonomy} 
Child_Sec_Bool  :  array  [0.. 50,0.. 4]  of  Boolean; 
{control  flag  for  parent  in  taxonomy} 
parent  :  array  [0.. 50,0.. 4]  of  Boolean; 

{control  flag  for  second  level  parent  in  taxonomy} 
Parent_Sec_Bool  :  array  [0.. 50,0.. 4]  of  Boolean; 
{control  flag  for  sibling  in  taxonomy} 
sibling  :  array  [0.. 50,0.. 4]  of  Boolean; 

test  :  string; 


begin 

{Standard  cgi  stuff} 
with  CGIEnvDatal  do 
begin 

websitelNIFilename  :=  paramstr(l) ; 
application. onException  :=  cgiErrorHandler; 
application.processMessages; 
createStdout ; 
sendPrologue ; 

{find  number  of  records} 
with  Table 1  do 
begin 

Tablel . open; 

N_R  :=  Tablel .RecordCount ; 


Tablel . close; 
end; 

{read  in  variables  from  applet  and  init  arrays} 

{strings  are  converted  to  float  or  int  where  appropriate} 
for  r  :=  0  to  N_R  do 
begin 

for  v  :=  0  to  4  do 
begin 

child [r,v]  :=  false; 

Child_Sec_Bool [r , v]  :=  false; 
parent [r,v]  :=  false; 

Parent_Sec_Bool[r,v]  :=  false; 
sibling [r,v]  :=  false; 

Var_All_Bool [r,v]  :=  false; 
end; 

end; 

{used  to  generate  the  queries} 

C  :=  ( ’Child’) ; 

P  :=  (’Parent’); 

{correspond  to  column  headings  in  Technolo.db} 
Category [0]  :=  C’tProblemArea’) ; 

CategoryCl]  :=  (’tFunctionalArea’); 

Category [2]  :=  ( ’tSolutionMethod’ ) ; 

Category [3]  :=  (’tlndType’) ; 

Category  [4]  :=  ( ’tOrgType ’ ) ; 

{user  selected  search  criteria-from  applet} 

Var_Value [0]  :=  GetSmallField(’tProblemArea’ ) ; 

Var .Value [1]  :=  GetSmallField (’ tFunctionalArea’ )  ; 
Var_ Value [2]  : =  GetSmallField ( ’ tSolutionMethod ’ ) ; 

Var .Value [3]  :=  GetSmallField ( ’tlndType’ ) ; 

Var.Value  [4]  :=  GetSmallField (’ tOrgType’ )  ; 

{user  selected  weights  and  degredation 
multipliers-from  applet} 

Temp .Weight [0]  :=  GetSmallField (’ Problem.Weight’) ; 
Weight [0]  :=  StrToFloat (Temp.Weight [0] ) ; 

Temp.Deg. Value [0 , 0]  :=  GetSmallField ( ’Problem.C.Deg’ ) 
Deg. Value  [0,0]  : =  StrToFloat (Temp.Deg.Value  [0,0]); 
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Temp_Deg_Value [0, 1]  :=  GetSmallFieldC ’Problem_P_Deg’ ) ; 
Deg_Value  [0,1]  : =  StrToFloat (Temp_Deg_Value [0,1]); 
Temp_Deg_Value [0,2]  :=  GetSmallFieldC ’Problem_S_Deg’) ; 
Deg_Value  [0,2]  : =  StrToFloat (Temp_Deg_Value [0,2]); 

Temp.Weight  [1]  :=  GetSmallFieldC ’Functional.Weight ’) ; 

Weight [1]  : =  StrToFloat (Temp_Weight [1] ) ; 

Temp_Deg_Value  [1 ,0]  :=  GetSmallFieldC ’Functional_C_Deg’ ) ; 
Deg_Value[l,0]  :=  StrToFloat CTemp_Deg_Value [1 ,0]  ) ; 
Temp_Deg_Value [1, 1]  :=  GetSmallFieldC ’Functional_P_Deg’ ) ; 
Deg.Value  [1,1]  : =  StrToFloat  CTemp_Deg_Value [1,1]); 
Temp_Deg_Value[l,2]  :=  GetSmallFieldC ’Functional_S_Deg’ ) ; 
Deg_Value [1 ,2]  :=  StrToFloat (Temp_Deg_Value[l, 2] ) ; 

Temp.weight [2]  :=  GetSmallFieldC ’Solution.Weight’) ; 

Weight [2]  : =  StrToFloat (Temp_Weight [2] ) ; 

Temp_Deg_Value [2 , 0]  :=  GetSmallFieldC ’Solution_C_Deg’ ) ; 
Deg_Value  [2,0]  :=  StrToFloat CTemp_Deg_Value [2,0]  ) ; 
Temp_Deg_Value [2, 1]  :=  GetSmallFieldC ’Solution_P_Deg’ ) ; 
Deg_Value  [2,1]  : =  StrToFloat  C Temp _Deg_ Value [2,1]); 

Temp_Deg_ Value [2,2]  :=  GetSmallFieldC ’ Solution_S_Deg’ ) ; 
Deg_Value [2 ,2]  : =  StrToFloat  CTemp_Deg_Value [2,2]); 

Temp_ Weight  [3]  : =  GetSmallFieldC ’ Industry .Weight ’ ) ; 

Weight [3]  : =  StrToFloat  CTemp.Weight [3] ) ; 

Temp_Deg_Value [3,0]  :=  GetSmallFieldC ’ Industry _C_Deg’ ) ; 
Deg.Value [3,0]  : =  StrToFloat  CTemp_Deg_Value [3,0]); 
Temp_Deg_Value [3, 1]  :=  GetSmallFieldC ’ Industry_P_Deg ’ ) ; 
Deg.Value [3,1]  : =  StrToFloat (Temp_Deg_Value [3,1]); 
Temp_Deg_Value [3,2]  :=  GetSmallFieldC ’ Industry_S_Deg’ ) ; 
Deg.Value  [3,2]  : =  StrToFloat (Temp_Deg_Value [3,2]); 

Temp.Weight [4]  :=  GetSmallFieldC ’ Organization.Weight’) ; 
Weight [4]  : =  StrToFloat  CTemp.Weight [4] ) ; 

Temp _Deg_Value [4,0]  :=  GetSmallFieldC ’0rganization_C_Deg’ ) ; 
Deg.Value [4,0]  : =  StrToFloat (Temp_Deg_Value [4,0]); 

Temp _Deg_ Value [4, 1]  :=  GetSmallFieldC ’0rganization_P_Deg’ ) ; 
Deg.Value [4,1]  : =  StrToFloat  CTemp_Deg_Value [4,1]); 
Temp_Deg_Value [4,2]  :=  GetSmallFieldC ’ 0rganization_S_Deg’ ) ; 
Deg.Value  [4,2]  : =  StrToFloat  CTemp_Deg_Value [4,2]); 

{ - } 

{quick  search  for  technologies  that  may  be  of  interest 
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send  from  Technolo.db  to  search_temp.db} 

{empty  Search_Temp.db> 
with  Table2  do 
begin 

Active  :=  False; 

DatabaseName  :=  ’ DNET ’ ; 

TableName  :=  ’Search_Temp’ ; 

TableType  :=  ttParadox; 

EmptyTable  ; 
end; 

{select  technologies  that  are  potentially  useful  and  send  them 
to  search_temp . db> 
with  Queryl  do 
begin 

for  v  :=  0  to  4  do 
begin 

Queryl. SQL. clear; 

Queryl. SQL. add  ( ’ SELECT  *  FROM  TECHNOLO ’ ) ; 

Queryl .SQL. add  (’ WHERE  ( ’ +  Category [v]  +  ’  =  " ’ 

+  Var_Value[v] 

Queryl. SQL. add  (’ORDER  BY  Provider ID, TechID’ ) ; 
BatchMovel . Execute ; 

Queryl . close ; 
end; 
end; 

{empty  Search_Temp_2.db> 
with  Table3  do 
begin 

Active  :=  False; 

DatabaseName  :=  ’DNET’; 

TableName  :=  ’Search_Temp_2’ ; 

TableType  : =  ttParadox ; 

EmptyTable; 

end; 

{remove  duplicate  records  from  Search.Temp . db  and  copy  results 
to  Search_Temp_2 . db} 
with  Table2  do 
begin 
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Query2 . SQL . clear ; 

Query2 . SQL . add  (’SELECT  DISTINCT  ProviderID,TechID, 
TechName , tProblemArea, tFunctionalArea , 
tSolutionMethod.tlndType ,tOrgType  ’) ; 

Query2 . SQL . add  (’  FROM  Search_Temp  ’); 

Query2.SQL.add  (’ORDER  BY  Provider ID’ ) ; 

BatchMove2 . Execute ; 

Query2. close; 
end; 

{ - - > 

{go  through  every  record  in  Search_Temp_2 . db  and  evaluate  its  value 
against  the  user  selections.  The  relevence  score  should  be  sent  to 
R_V_S[r,v]  for  later  use  in  calculating  T_S} 

with  Table3  do 

{find  the  number  of  records  in  Search_Temp_2 .  db> 
begin 

Table3.open; 

N_T_R  :=  Table3.RecordCount; 

Table3. close; 

{initialize  arrays} 

C_2_Temp  : =  ( ’  ’ ) ; 

P_2_Temp  : =  ( ’  ’ ) ; 
for  r  :=  0  to  N_T_R  do 
begin 

for  v  :=  0  to  4  do 
begin 

R_V_S[r,v]  :=  (0.0); 
info[r,v]  :=  (’  ’); 
temp[r,v]  :=(’’); 
end; 

T_S[r]  :=  (0.0); 
end; 

end; 

with  Table3  do 
begin 

Table3 . open; 

Table3.First() ; 

{read  in  one  record  at  a  time  to  analyze  the  variables} 
for  r  :=  0  to  (N_T_R  -  1)  do 
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begin 
{3  to 


7  are  actual  field  #s  in  db} 


temp[r,0] 
temp [r, 1] 
temp [r, 2] 
temp [r , 3] 
temp [r, 4] 


Table3 .Fields [3] .AsString; 
Table3. Fields [4] .AsString; 
Table3. Fields [5] .AsString; 
Table3. Fields [6] .AsString; 
Table3. Fields [7] .AsString; 


info[r,0] 
infoCr, 1] 
info[r,2j 


Table3. Fields [0] .AsString; 
Table3 .Fields [1] .AsString; 
Table3 .Fields [2] .AsString; 


Table3.Next() ; 
end; 

Table3. close; 
end; 


{check  for  relationships  and  turn  on  boolean  flags  once  a 
relationship  has  been  established.  Order  of  precedence: 
user  selected  All,  exact  variable  match,  child,  sibling, 
parent,  second  level  child,  second  level  parent} 


with  Query4  do 
begin 

for  r  :=  0  to  (N_T_R  -  1)  do 
begin 

for  v  :=  0  to  4  do 
begin 

{if  user  selects  ALL  we  consider  it  a  match} 
if  (Var_Value [v]  =  ’ALL')  then 
begin 

Var_All_Bool [r, v]  :=  True; 
end; 

{a  match  is  assigned  a  score  of  1.0} 
if  (Var_Value [v]  =  temp[r,v])  then 
begin 

Match_Bool [r,v]  :=  True; 
end; 

{check  for  child  relationships} 
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if  (Var_All_Bool [r, v]  <>  True)  and 
(Match_Bool [r,v]  <>  True)  then 
begin 

with  Table5  do 
begin 

Active  :=  False; 

DatabaseName  :=  ’DNET’ ; 

TableName  :=  ’Search_Temp_3’ ; 

TableType  :=  ttParadox; 

EmptyTable ; 
end; 

Query4 . SQL . clear ; 

Query4.SQL.add  (’SELECT  *  FROM  Taxonomy’); 
Query4 . SQL . add  (’WHERE  (’+C+’  =  " ’ +Var_Value [v] 
+’"  AND  ’+P+’  =  "’+temp[r,v]  +  ’")’); 
Bat chMove3 . Execute ; 

Query4 . close ; 
with  Table5  do 
begin 

Table5.open; 

if  Tables. Re cordCount  >  0  then 
begin 

child [r,v]  :=  True; 
end; 

Table5. close; 
end; 

end; 

{check  for  parent  relationship} 
if  ( Var_All_Bool [r , v]  <>  True)  and 
(Match_Bool[r,v]  <>  True)  and 
(child[r,v]  <>  True)  then 
begin 

with  Table5  do 
begin 

Active  :=  False; 

DatabaseName  :=  ’DNET’ ; 

TableName  :=  ’Search_Temp_3’ ; 

TableType  :=  ttParadox; 

EmptyTable; 

end; 

Query4. SQL. clear; 
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Query4 . SQL . add  (’SELECT  *  FROM  Taxonomy’); 

Query4 . SQL . add  (’WHERE  (’+C+’  =  "’+temp[r,v]+’ "  AND  ’ 
+P+’  =  » > +Var_Value [v] + 

BatchMove3 . Execute ; 

Query4. close; 
with  Table5  do 
begin 

Table5.open; 

if  Table5.RecordCount  >  0  then 
begin 

parent [r,v]  :=  True; 
end; 

Table5. close; 
end; 

end; 

■(check  for  sibling  relationship} 
if  (Var_All_Bool [r ,  v]  <>  True)  and 
(Match_Bool [r, v]  <>  True)  and 
(child [r,v]  <>  True)  and 
(parent [r,v]  <>  True)  then 
begin 

with  Table5  do 
begin 

Active  :=  False; 

DatabaseName  :=  ’DNET’; 

TableName  :=  ’ Search_Temp_3 ’ ; 

TableType  :=  ttParadox; 

EmptyTable ; 
end; 

Query4. SQL. clear; 

Query4 . SQL . add  (’SELECT  *  FROM  Taxonomy’); 

Query4 . SQL . add  (’WHERE  (’+C+’  =  "’ +Var_Value [v] +’")’) ; 
BatchMove3 . Execute ; 

Query4. close; 

with  Table5  do 
begin 

Table5.open; 

Table5. First () ; 

P_Temp  :=  Table5 .Fields [0] .AsString; 

Table5. Close () ; 
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{check  to  see  if  Parent  is  on  top  level 
-that  is  a  meaningless  relationship} 
if  (P_Temp  <>  ’Problem  Area’)  and 
(P_Temp  <>  ’Functional  Area’)  and 

(P_Temp  <>  ’Solution  Method’)  and 
(P_Temp  <>  ’Industry  Type’)  and 

(P_Temp  <>  ’Organization  Type’)  then 
begin 

Query4 . SQL . clear ; 

Query4 . SQL . add  ( ’ SELECT  *  FROM  Taxonomy ’ ) ; 
Query4.SQL.add  (’WHERE  (’+C+’  =  "’+temp [r,v] 
+’ "AND  ’+P+’  =  " ’+P_Temp+  ’")’); 
BatchMove3 . Execute ; 

Query4. close; 

Table5.open; 

k  :=  Table5.RecordCount ; 

Table5. Close () ; 

if  (k  >  0)  then 
begin 

sibling[r,v]  :=  True; 
end; 

end; 

end; 

end; 

{check  for  second  level  child  relationship} 
if  (Var_All_Bool [r,v]  <>  True)  and 
(Match_Bool [r ,v]  <>  True)  and 

(child [r,v]  <>  True)  and 
(parent [r,v]  <>  True)  and 

(sibling [r,v]  <>  True)  then 
begin 

with  Table6  do 
begin 

Active  :=  False; 

DatabaseName  :=  ’DNET’; 

TableName  :=  ’Tax_Temp’ ; 

TableType  :=  ttParadox; 

EmptyTable ; 
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end; 


Query4 . SQL . clear ; 

Query4.SQL.add  ( ’ SELECT  *  FROM  Taxonomy’); 
Query4.SQL.add  (’WHERE  C’+C+’  =  "’ 

+Var_Value [v] +’")’); 

BatchMove4 . Execute ; 

Query4. close; 

with  Table6  do 
Table6.open; 

Table6 .First () ; 
begin 

j  : =  Table6 . RecordCount ; 
for  i  :=  0  to  (j)  do 
begin 

C_2_Temp  :=  Table6. Fields [0] .AsString; 
if  (C_2_Temp  <>  ’Problem  Area’)  and 
(C_2_Temp  <>  ’Functional  Area’)  and 

(C_2_Temp  <>  ’Solution  Method’)  and 
(C_2_Temp  <>  ’Industry  Type’)  and 

(C_2_Temp  <>  ’Organization  Type’)  then 

begin 

Query4. SQL. clear; 

Query4 . SQL . add  (’SELECT  *  FROM  Taxonomy’); 
Query4 . SQL . add  (’WHERE  (’+P+’  =  " ’ +temp [r , v] 
+’"  AND  ’+C+’  =  " ’ +C_2_Temp+  ’")’); 

BatchMove5 . Execute ; 

Query4. close; 

with  Table?  do 
begin 

Table7.open; 

k  :=  Table7. RecordCount; 

Table7. Close (); 

if  (k  >  0)  then 
begin 

Child_Sec_Bool  [r, v]  :=  True; 
end; 

end; 
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end; 

Table6 .Next () ; 
end; 

end; 

Table6. Close () ; 

end; 

{check  for  second  level  parent  relationship} 
if  (Var_All_Bool[r,v]  <>  True)  and 
(Match.Bool [r,v]  <>  True)  and 

(child [r,v]  <>  True)  and 
(parent [r,v]  <>  True)  and 

(sibling [r,v]  <>  True)  and 
(Child_Sec_Bool [r,v]  <>  True)  then 

begin 

with  Table6  do 
begin 

Active  :=  False; 

DatabaseName  :=  ’DNET’ ; 

TableName  :=  ’Tax.Temp’; 

TableType  : =  ttParadox ; 

EmptyTable; 

end; 

Query4 . SQL . clear ; 

Query4 . SQL . add  (’SELECT  *  FROM  Taxonomy’); 
Query4.SQL.add  (’WHERE  (’+P+’  =  "’ 

+Var .Value [v] +’")’) ; 
BatchMove4 . Execute ; 

Query4. close; 

with  Table6  do 
Table6.open; 

Table6 .First () ; 
begin 

j  : =  Table6 . RecordCount ; 

for  i  :=  0  to  j  do 
begin 

P_2_Temp  :=  Table6.Fields[l] .AsString; 
Query4 . SQL . clear ; 
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Query4 . SQL . add  ( ’ SELECT  *  FROM  Taxonomy’); 
Query4 . SQL . add  (’WHERE  (’+P+’  =  " ’ +P_2_Temp+ ’ " 
AND  ’ +C+ ’  =  " ’+temp[r,v] + 

BatchMove5 . Execute ; 

Query4. close; 

with  Table7  do 
begin 

Table7 . open; 

k  :=  Table7.RecordCount; 

Table7. Close ()  ; 

if  k  >  0  then 
begin 

Parent_Sec_Bool [r,v]  :=  True; 
end; 
end; 

Table6.Next () ; 
end; 
end; 

Table6. Close (); 

end; 

end; 

end; 

end; 


{evaluate  booleans  and  set  the  R_V_S  accordingly} 

for  r  :=  0  to  (N_T_R  -  1)  do 
begin 

for  v  :=  0  to  4  do 
begin 

{if  user  selects  ALL  we  consider  it  a  match} 
if  (Var_All_Bool [r , v]  =  True)  then 
begin 

R_V_S [r, v]  :=  1.0 
end 

{a  match  is  assigned  a  score  of  1.0} 
else  if  (Match_Bool [r , v]  =  True)  then 
begin 

R_V_S [r , v]  : =  1 . 0 
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end 


{query  taxonomy. db  for  child  relationship} 
else  if  (child[r,v]  =  True)  then 
begin 

R_V_S [r ,v]  :=  Deg.Value [v,0] 
end 

{query  taxonomy. db  for  parent  relationship} 
else  if  (parent [r,v]  =  True)  then 
begin 

R_V_S[r,v]  :=  Deg_Value[v,l] 
end 

{query  taxonomy. db  for  sibling  relationship} 
else  if  (sibling [r,v]  =  True)  then 
begin 

R_V_S[r,v]  :=  Deg_Value [v,2] 
end 

{query  taxonomy. db  for  second  level  child  relationship} 
else  if  (Child_Sec_Bool [r, v]  =  True)  then 
begin 

R_ V_S [r ,  v]  : =  Deg_Value [v , 0] *Deg_ Value [v , 0] 
end 

{query  taxonomy. db  for  second  level  parent  relationship} 
else  if  (Parent_Sec_Bool [r,v]  =  True)  then 
begin 

R_V_S[r,v]  :=  Deg_Value [v, 1] *Deg_Value [v, 1] 
end 

{if  technology  is  listed  as  all  we  assign  a  score  of  0.5} 
else  if  (temp[r,v]  =  ’ALL'  )  then 
begin 

R_V_S [r,v]  :=  0.5 
end 

{no  useful  result  yields  a  score  of  0.0} 
else 
begin 

R_V_S [r , v]  :=  0.0; 
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end; 

end; 

end; 


{Calculate  the  Total  Score  for  each  record  in  Search_Temp_2.db> 

for  r  :=  0  to  (N_T_R  -  1)  do  {should  use  RecordCount} 
begin 

T_S[r]  :=  ((Weight [0] )*(R_V_S[r,0] ))  + 

( (Weight [1] )*(R_V_S [r, 1] ))  + 

( (Weight  [2] ) * (R_V_S [r , 2] ) )  + 

( (Weight  [3] ) * (R_V_S [r , 3] ) )  + 

( (Weight  [4] ) * (R_V_S [r , 4] ) ) ; 

end; 


{standard  header  information} 

{all  instances  of  the  character  &  are  for  output  parsing  and 
have  no  effect  on  the  search} 

senc*(  ’  DecisionNet  Search  Engine  Results'  +  ’&’  ); 

send( 

{user  selection  information} 

send ( ’User  Selections : ’+  ’&’); 

send (’Problem  Area  =  ’  +  Var.Value [0] +  ’&’); 

send (’Functional  Area  =  ’  +  Var_ Value [1] +  ’&’); 

send (’Solution  Method  =  ’  +  Var_ Value [2] +  ’&’); 

send (’Industry  Type  =  ’  +  Var.Value [3] + 

send(’ Organization  Type  =  ’  +  Var.Value [4] +  ’&’); 

send( ’  ’+’&’); 

send ( ’Problem  Area  Weight  =  ’  +  FloatToStr(Weight [0] )  +  ’&'); 
send (’Functional  Area  Weight  =  ’  +  FloatToStr (Weight [1] )  + 
send (’Solution  Method  Weight  =  ’  +  FloatToStr (Weight [2] )  +  ’&’); 
send(’ Industry  Type  Weight  =  ’  +  FloatToStr (Weight [3] )  +’&’); 
send(’ Organization  Type  Weight  =  ’  +  FloatToStr(Weight [4] )  +  ’&’); 
send( ’  ’+  ’&’ ) ; 

{sends  T_S  and  R_V_S  array  values  for  individual  technologies} 

for  r  :=  0  to  (N_T_R  -  1)  do 
begin 
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send ( ' TechID  =  >  +  inforr  n  .  ,  „ 

send('  >+  >&>).  ’  TechName  =  >  +  info[r,2]+  >&>)■ 

sendC'Relevency  Score  =  >  +  P1 

send C ’Score  for  (Problem  Area)°= CToStr(T-sM>  + 

’  +  FloatToStr(R_V_S[r,v])+  >&>). 
send  ’Score  for  (Functional  Area)  -  ' 

+  Float ToStr (R_  V_S [r,v])+ 
send_(- Score  for  (Solution  Method)  « 

+  F1°atToStr(R_V_S[r,v])+  >&>) . 

send (’Score  for  (Industry  Type)  =  ’ 

*Z  Float ToStr (R_ V_S [r , v] )  +  >&>). 
send(’Score  for  (Organiration  Type)  I 

send(”!  ;a0°Str(R-V-S[r-V])*  ’**>: 

end  ; 

{standard  footer  information} 

School.’+  >&>  ).  g  at  the  Naval  Postgraduate 

aend(  ’Generated  on''  +  »ebdate(nov)  *  >*.). 

closeStdout ; 

closeAppC  application  ); 
end; 

end; 

end. 


133 


134 


APPENDIX  P.  TAXONOMY  LEVEL  1 


Object  Type 

ALL 

Object  Type 

Algorithm 

Object  Type 

Data  Set 

Object  Type 

Decision  Support  System 

Object  Type 

Example 

Object  Type 

Model  Schema 

Object  Type 

Modeling  Language 

Object  Type 

Solver 

Problem  Area 

ALL 

Problem  Area 

Asset  Pricing 

Problem  Area 

Assignment 

Problem  Area 

Bin  packing 

Problem  Area 

Capital  budgeting 

Problem  Area 

Communications  networks 

Problem  Area 

Corporate  strategy 

Problem  Area 

Cost  analysis 

Problem  Area 

Crew  scheduling 

Problem  Area 

Depreciation 

Problem  Area 

Environment  systems  analysis 

Problem  Area 

Facilities/equipment  planning 

Problem  Area 

Fire  models 

Problem  Area 

Hierarchical  production  planning 

Problem  Area 

Inventory 

Problem  Area 

Investment 

Problem  Area 

Knapsack  problem 

Problem  Area 

Job  shop  scheduling 

Problem  Area 

Layout/Location  of  equipment 

Problem  Area 

Learning/Training 

Problem  Area 

Lifecycle 

Problem  Area 

Location  analysis 

Problem  Area 

Maintenance/Repair 

Problem  Area 

Manpower  planning 

Problem  Area 

Material  Handling 

Problem  Area 

Planning 

Problem  Area 

Production 

Problem  Area 

Quality  Control 

Problem  Area 

Reliability  of  systems 

Problem  Area 

Risk  assessment/management 

Problem  Area 

Safety 
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Problem  Area 

Scheduling/ sequencing 

Problem  Area 

Taxation 

Problem  Area 

Utility/Preferences 

Problem  Area 

Vehicle  routing 

Problem  Area 

Yield  management 

Functional  Area 

ALL 

Functional  Area 

Administration 

Functional  Area 

Engineering 

Functional  Area 

Finance 

Functional  Area 

Legal 

Functional  Area 

Logistics 

Functional  Area 

Maintenance 

Functional  Area 

Marketing 

Functional  Area 

Payroll 

Functional  Area 

Personnel 

Functional  Area 

Shopping 

Functional  Area 

Supply 

Functional  Area 

Testing 

Functional  Area 

Training 

Functional  Area 

Transportation 

Functional  Area 

Telecommunications 

Industry  Type 

ALL 

Industry  Type 

Aerospace/Space 

Industry  Type 

Accounting 

Industry  Type 

Agriculture 

Industry  Type 

Arts 

Industry  Type 

Business/ Commerce 

Industry  Type 

Communications 

Industry  Type 

Construction 

Industry  Type 

Consumer 

Industry  Type 

Economics 

Industry  Type 

Education 

Industry  Type 

Emergency  Services 

Industry  Type 

Energy 

Industry  Type 

Engineering 

Industry  Type 

Entertainment /Med i a 

Industry  Type 

Environment/Ecology 

Industry  Type 

Finance 

Industry  Type 

Government 

Industry  Type 

Health/Medicine 

Industry  Type 

International  Trade 

Industry  Type 

Labor 
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Industry  Type 

Law 

Industry  Type 

Libraries 

Industry  Type 

Manufacturing 

Industry  Type 

Marketing 

Industry  Type 

Military 

Industry  Type 

Natural  Resources 

Industry  Type 

Petro-Chemical 

Industry  Type 

Population 

Industry  Type 

Recreation  and  Sports 

Industry  Type 

Scientific  Research 

Industry  Type 

Transportation 

Organization  Type 

ALL 

Organization  Type 

Military 

Organization  Type 

Government (non-military) 

Organization  Type 

Commercial 

Organization  Type 

Non-commercial/non-prof  it 

Organization  Type 

Personal/Individual 

Solution  Area 

ALL 

Solution  Area 

Simulation/stochastic  modeling 

Solution  Area 

Statistics/probability 

Solution  Area 

Gaming 

Solution  Area 

Linear  Programming 

Solution  Area 

Optimization 

Solution  Area 

Numerical  Math 

Solution  Area 

Spreadsheet  modeling 

Solution  Area 

Knowledge  based 

Solution  Area 

Symbolic  Math (calculus) 

Solution  Area 

Decision  Analysis 

Solution  Area 

Other 

137 


APPENDIX  Q.  TAXONOMY  LEVEL  2 


Agriculture 

Agriculture 

Agriculture 

Agriculture 

Arts 

Arts 

Arts 

Business/Commerce 

Business/Commerce 

Business/Commerce 

Business/Commerce 

Business/Commerce 

Construction 

Construction 

Economics 

Economics 

Education 

Education 

Education 

Education 

Education 

Emergency  Services 

Emergency  Services 

Emergency  Services 

Entertainment /Media 

Entertainment /Media 

Entertainment /Media 

Entertainment/Media 

Entertainment/Media 

Entertainment/Media 

Environment/Ecology 

Environment/Ecology 

Environment/Ecology 

Environment/Ecology 

Environment/Ecology 

Finance 

Finance 

Finance 

Finance 


Crops 

Food  Production 

Livestock 

Weather 

Fine  Arts 

Music 

Theater 

Apparel 

General  Retailing 

Mail-order 

Restaurant 

Wholesale 

Architecture 

Materials 

Macroeconomics 

Microeconomics 

K-12 

Undergraduate 

Graduate 

Career  training 

Vocational 

Fire 

Police 

Hospitals 

Broadcasting 

Film 

Music 

Publishing 

Radio 

Television 

Air  quality 

Forestry 

Pollution 

Recycling 

Water  quality 

Banking 

Insurance 

Investment 

Mortgage 
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Finance 

Finance 

Government 

Government 

Government 

Government 

Government 

Government 

Health/Medi c ine 

Health/Medicine 

Health/Medi cine 

Libraries 

Manufacturing 

Manufacturing 

Manufacturing 

Manuf actur ing 

Manufacturing 

Manufacturing 

Manuf  actur ing 

Manuf  actur ing 

Manuf  actur ing 

Manuf  actur ing 

Military 

Military 

Military 

Military 

Military 

Military 

Military 

Scientific  Research 
Scientific  Research 
Scientific  Research 
Scientific  Research 
Scientific  Research 
Scientific  Research 
Scientific  Research 
Scientific  Research 
Transportation 
Transportation 
Transportation 
Transportation 
Transportation 


Personal 

Real  Estate 

Elections 

Energy  Policy 

Public  Works 

Regulations 

Tax  Policy 

Urban  Systems 

Exercise 

Health  care 

Nutrition 

Archives 

Aerospace 

Automotive 

Building  materials 

Chemical 

Clothing/Textiles 
Forest/Paper  products 
Furniture 
Metals 

Pharmac  eut i c al s 
Plastics . 

Avionics 

Command  and  Control 

Data  processing 

Simulation 

Software  tools 

Telecommunications 

Testing 

Chemistry 

Geography 

Engineering 

Mathematics 

Meteorology 

Oceanography 

Physics 

Statistics 

Airline 

Automobile 

Cargo 

Railroad 

Shipping 
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Simulation/stochastic  modeling 

Simulation/stochastic  modeling 

Simulation/stochastic  modeling 

Statistics/probability 

Statistics/probability 

Optimization 

Optimization 

Numerical  Math 

Numerical  Math 

Numerical  Math 

Numerical  Math 

Numerical  Math 

Numerical  Math 

Symbolic  Math (cal cuius) 

Symbolic  Math (calculus) 

Symbolic  Math (calculus) 

Symbolic  Math (calculus) 

Decision  Analysis 

Decision  Analysis 

Decision  Analysis 

Decision  Analysis 

Decision  Analysis 


Simulation 

Queuing 

Reliability 

Approximation 

Statistics, Probability 

Linear  Algebra 

Optimization 

Arithmetic 

Number  theory 

Elementary/special  functions 
Interpolation 
Nonlinear  equations 
Approximation 

Elementaxy/Special  Functions 
Diff erentiation/integration 
Differential/integral  equations 
Integral  transforms 
Decision  Trees 
Utility  Theory 
Influence  Diagrams 
AHP 

Risk  Analysis 
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APPENDIX  R.  TAXONOMY  LEVEL  3 


This  file  has  been  formatted  for  display.  Where  line 
breaks  appear,  it  is  only  to  fit  the  text  on  this  page.  The 
actual  data  file  has  no  blank  lines  and  the  child  variable 
always  starts  at  character  position  39. 


Simulation 

Simulation 

Reliability 

Reliability 

Approx imat i on 

Approximation 

Approximation 

Approximation 
Approximation 
Approximation 
Approximation 
Approximation 
Approximation 
Statistics, Probability 
Statistics, Probability 
Statistics , Probability 
Statistics, Probability 
Statistics, Probability 
Statistics, Probability 
Statistics, Probability 
Statistics, Probability 
Statistics , Probability 
Statistics, Probability 
Statistics .Probability 
Statistics , Probability 
Statistics, Probability 
Statistics, Probability 
Statistics, Probability 
Statistics .Probability 
Statistics, Probability 
Statistics, Probability 
Linear  Algebra 
Linear  Algebra 


Discrete 

Continuous (Markov) 

Quality  control 

Electrical  network 

Least  squares  approximation 

Minimax  approximation 

Least  absolute  value 

approximation 

Other  approximations 

Smoothing 

Service  routines, approximation 
Grid  or  knot  generation 
Manipulation  of  basis  functions 
Other 

Data  Summarization 
Data  manipulation 
Elementary  statistical  graphics 
Elementary  data  analysis 
Function  evaluation 
Random  number  generation 
Analysis  of  variance 
Regression 

Categorical  data  analysis 
Time  series  analysis 
Correlation  analysis 
Discriminant  analysis 
Covariance  structure  models 
Cluster  analysis 
Life  testing, survival  analysis 
Random  number  generation 
Multidimensional  scaling 
Statistical  data  sets 
Systems  of  linear  equations 
Determinants 
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Linear  Algebra 
Linear  Algebra 

Linear  Algebra 

Linear  Algebra 

Linear  Algebra 

Linear  Algebra 

Optimization 

Optimization 

Optimization 

Optimization 

Arithmetic 

Arithmetic 

Arithmetic 

Arithmetic 

Arithmetic 

Arithmetic 

Arithmetic 

Elementary/special  functions 
Elementary/ special  functions 
Element ary /special  functions 
Elementary/special  functions 

Elementary/special  functions 

Elementary/special  functions 
Elementary/special  functions 
Elementary/special  functions 
Elementary/special  functions 
Elementary/special  functions 

Element ary /special  functions 
Element ary /special  functions 

Elementary/special  functions 
Elementary/special  functions 
Elementary/special  functions 
Elementary/special  functions 
Elementary/special  functions 
Elementary/special  functions 
Interpolation 
Interpolation 


Eigenvalues , eigenvectors " 

QR  decomposition/Gram-Schmidt 

orthogonalization 

Singular  value  decomposition 

Update  matrix  decomposition 

Other  matrix  equations 

Generalized  inverses 

Unconstrained 

Constrained 

Optimal  Control 

Service  routines 

Integer 

Rational 

Real 

Complex 

Interval 

Change  of  representation 
Sequences 

Integer-valued  functions 
Powers , roots , reciprocals 
Polynomials 

Elementary  transcendental 
functions 

Exponential/logarithmic 

integrals 

Gamma 

Error  functions 
Legendre  functions 
Bessel  functions 
Confluent  hypergeometric 
functions 

Coulomb  wave  functions 
Jacobian  elliptic 
functions/theta 
Elliptical  integrals 
Weierstrass  elliptic  functions 
Parabolic  cylinder  functions 
Mathieu  functions 
Spheroidal  wave  functions 
Other  special  functions 
Univariate  data 
Multivariate  data 
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Interpolation 
Nonlinear  equations 
Nonlinear  equations 
Nonlinear  equations 
Approximation 
Approximation 
Approximation 

Approximation 

Approximation 

Approximation 

Approximation 

Approximation 

Approximation 

Approximation 

Elementary/ special  functions 
Elementary/special  functions 
Elementary/special  functions 
Differentiation,  integration 
Differentiation,  integration 
Differential/integral  equations 
Differential/integral  equations 
Differential/integral  equations 
Integral  transforms 

Integral  transforms 
Integral  transforms 
Integral  transforms 


Service  routines, interpolation 

Single  equation 

System  of  equations 

Service  routine 

Least  squares  approximation 

Minimax  approximation 

Least  absolute  value 

approximation 

Other  analytic  approximations 
Smoothing 

Service  routines, approximation 
Grid  or  Knot  generation 
Manipulation  of  basis  functions 
Other 

Nonlinear  least  squares 
Integer  valued  functions 
Powers , roots , recipricals 
Polynomials 

Multidimensional  integrals 

Service  routines 

Ordinary  differential  equations 

Partial  differential  equations 

Integral  equations 

Trigonometric/fast  Fourier 

transforms 

Convolutions 

Laplace  transforms 

Hilbert  transforms 
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APPENDIX  S.  TAXONOMY  LEVEL  4 


This  file  has  been  formatted  for  display.  Where  line 
breaks  appear,  it  is  only  to  fit  the  text  on  this  page.  The 
actual  data  file  has  no  blank  lines  and  the  child  variable 
always  starts  at  character  position  39. 


Least  squares  approximation 
Least  squares  approximation 
Service  routines  for  approx 
Data  Summarization 
Data  Summarization 
Data  Summarization 
Data  manipulation 
Data  manipulation 
Data  manipulation 
Data  manipulation 
Data  manipulation 
Elementary  statistical  graphics 
Elementary  statistical  graphics 
Elementary  statistical  graphics 
Elementary  statistical  graphics 
Elementary  data  analysis 
Elementary  data  analysis 
Elementary  data  analysis 
Elementary  data  analysis 
Function  evaluation 
Function  evaluation 
Random  number  generation 
Random  number  generation 
Random  number  generation 
Analysis  of  variance 
Analysis  of  variance 
Analysis  of  variance 
Analysis  of  variance 
Analysis  of  variance 
Analysis  of  variance 
Analysis  of  variance 
Regression 
Regression 
Regression 


Linear  least  squares 

Nonlinear  least  squares 

Evaluation  of  fitted  functions 

One-dimensional  data 

Two-dimensional  data 

Multi-dimensional  data 

Transform 

Tally 

Subset 

Merge 

Construct  new  variables 

One-dimensional  data 

Two-dimensional  data 

Three-dimensional  data 

Multi-dimensional  data 

One-dimensional  data 

Two-dimensional  data 

Multi-dimensional  data 

Multiple  Multi-dimensional  data 

Univariate 

Multivariate 

Univariate 

Multivariate 

Service  routines 

One-way 

Two-way 

Three-way 

Multi-way 

Multivariate 

Generate  experimental  designs 

Service  routines 

Simple  linear 

Polynomial 

Multiple  linear 
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Regression 

Regression 

Regression 

Regression 

Regression 

Regression 

Categorical  data  analysis 
Categorical  data  analysis 
Categorical  data  analysis 
Categorical  data  analysis 
Time  series  analysis 
Time  series  analysis 
Cluster  analysis 
Cluster  analysis 
Cluster  analysis 
Cluster  analysis 
Systems  of  linear'  equations 
Systems  of  linear  equations 
Systems  of  linear  equations 
Systems  of  linear  equations 
Systems  of  linear  equations 
Determinants 
Determinants 
Determinants 
Determinants 

Eigenvalues , eigenvectors 

Eigenvalues , eigenvectors 

Eigenvalues , eigenvectors 

Update  matrix  decomposition 

Update  matrix  decomposition 

Update  matrix  decomposition 

Update  matrix  decomposition 

Generalized  inverses 

Generalized  inverses 

Generalized  inverses 

Unconstrained 

Unconstrained 

Constrained 

Constrained 

Constrained 

Constrained 

Constrained 


Polynomial  in  several  variables 

Nonlinear 

Simultaneous 

Spline 

EDA 

Service  routines 
2  by  2  tables 
Two-way  tables 
Log-linear  model 
EDA 

Univariate 

Two  time  series 

One-way 

Two-way 

Display 

Service  routines 
Real  nonsymmetric  matrices 
Real  symmetric  matrices 
Complex  non-Hermitian  matrices 
Complex  Hermitian  matrices 
Associated  operations 
Real  nonsymmetric  matrices 
Real  symmetric  matrices 
Complex  non-Hermitian  matrices 
Complex  Hermitian  matrices 
Ordinary  eigenvalue  problems 
Generalized  eigenvalue  problems 
Associated  operations 
LU 

Cholesky 

QR 

Singular  value 

Unconstrained 

Constrained 

Generalized  inverses 

Univariate 

Multivariate 

Linear  programming 

Transportation/ assignment 

Integer  programming 

Network 

Quadratic  programming 


Constrained 

Constrained 

Constrained 

Constrained 

Service  routines 

Service  routines 

Service  routines 

Service  routines 

Service  routines 

Real 

Real 

Real 

Complex 

Complex 

Complex 

Change  of  representation 
Change  of  representation 
Polynomials 
Polynomials 

Elementary  transcendental  functions 

Elementary  transcendental  functions 

Elementary  transcendental  functions 

Elementary  transcendental  functions 

Gamma 

Gamma 

Gamma 

Gamma 

Gamma 

Gamma 

Gamma 

Error  functions 

Error  functions 
Error  functions 
Bessel  functions 
Bessel  functions 
Bessel  functions 
Bessel  functions 
Bessel  functions 
Bessel  functions 
Univariate  data 


Geometric  programming 
Dynamic  programming 
General  nonlinear  programming 
Problem  input 
Problem  scaling 

Check  user-supplied  derivatives 
Find  feasible  point 
Check  for  redundancy 
Other 

Standard  precision 

Extended  precision 

Extended  range 

Standard  precision 

Extended  precision 

Extended  range 

Base  conversion 

Decomposition, construction 

Orthoginal 

Non-orthogonal 

Trigonometric , inverse 

trigonometric 

Exponential,  logarithmic 

Hyperbolic,  inverse  hyperbolic 

Integrals 

Gamma/log  gamma/reciprocal  gamma 

Beta/log  beta 

Psi  functions 

Polygamma  functions 

Incomplete  gamma 

Incomplete  beta 

Riemann  zeta 

Functions/ inverses/integral/ 

distributions 

Fresnel  integrals 

Dawson ’ s  integral 

J/Y/H_l/H_2 

I/K 

Kelvin  functions 
Airy  and  Scorer 
Stuve/Anger /Weber 
Integrals  of  Bessel 
Polynomial  splines 
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Univariate  data 

Univariate  data 

Multivariate  data 

Multivariate  data 

Service  routines , interpolation 

Service  routines , interpolation 

Service  routines , interpolation 

Service  routines, interpolation 

Single  equation 

Single  equation 

Least  squares  approximation 

Least  squares  approximation 

Service  routines , approximation 

Other 

Other 

Nonlinear  least  squares 
Nonlinear  least  squares 
Polynomials 
Polynomials 

Multidimensional  integrals 
Multidimensional  integrals 
Ordinary  differential  equations 
Ordinary  differential  equations 
Ordinary  differential  equations 
Partial  differential  equations 
Partial  differential  equations 
Trigonometric/fast  Fourier 
Trigonometric/fast  Fourier 


Polynomials 
Other  functions 
Gridded 
Scattered 

Evaluate  fitted  functions 
Grid  or  knot  generation 
Manipulation  of  basis  functions 
Other 

Polynomial 

Nonpolynomial 

Linear  least  squares 

Nonlinear  least  squares 

Evaluation  of  fitted  functions 

Unconstrained 

Constrained 

Unconstrained 

Constrained 

Orthogonal 

Non-orthogonal  on  grid 
hyper-rectangular  regions 
n-dimensional  quadrature 
Initial  value 
Multipoint  boundary  value 
Service  routines 
Initial  boundary  value 
Elliptic  boundary  value 
One-dimensional 


transf orms 
transforms  Multidimensional 


150 


LIST  OF  REFERENCES 


[1]  Library  of  Congress.  Library  of  Congress,  1997.  [http://rs7tr0.loc.gov/]. 

[2]  Frankfurt  University.  The  Java  Repository,  1997.  [http:// 
java.  wiwi.  uni.fr  ankurt  .de: 8080 /j  ava/owa /jr_search] . 

[3]  H.  Bhargava.  Welcome  to  Decisionnet,  1997.  [http://dnet.sm.nps.navy.mil/]. 

[4]  Excite  Inc.  Excite  Search,  1997.  [http://www.excite.com]. 

[5]  Lycos  Inc.  Lycos,  Your  Personal  Internet  Guide,  1997.  [http://www.lycos.com]. 

[6]  H.  Bhargava,  A.  King,  and  D.  McQuay.  Decisionnet:  An  Architecture  for  Mod¬ 
eling  and  Decision  Support  over  the  World  Wide  Web.  In  Tung  X.  Bui,  edi¬ 
tor,  Proceedings  of  the  Third  International  Society  for  Decision  Support  Systems 
Conference,  Vol.  II,  pages  541-550,  Hong  Kong,  1995.  International  Society  for 
DSS. 

[7]  S.H.  Earley.  Decisionnet:  A  Database  Approach.  Master’s  thesis,  Naval  Post¬ 
graduate  School,  1996. 

[8]  P.M.  Rogers.  Indexing  and  Retrieval  in  Digital  Libraries:  Developing  Taxonomies 
for  a  Repository  of  Decision  Technologies.  Master’s  thesis,  Naval  Postgraduate 
School,  1996. 

[9]  R.  Boisvert.  The  Guide  to  Available  Mathematical  Software  Problem  Classifica¬ 
tion  System.  Communications  in  Statistics,  part  B-Simulation  and  Computation, 
20(4),  1991. 

[10]  D.  Flanagan.  Java  in  a  Nutshell.  OReilly  and  Associates,  1996. 

[11]  A.  Taylor.  JDBC  Developer’s  Resource.  Prentice  Hall  PTR,  1997. 


151 


152 


INITIAL  DISTRIBUTION  LIST 


1.  Defense  Technical  Information  Center .  2 

8725  John  J.  Kingman  Rd.,  Ste  0944 

Ft.  Belvoir,  VA  22060-6218 

2.  Dudley  Knox  Library .  2 

Naval  Postgraduate  School 

411  Dyer  Rd. 

Monterey,  CA  93943-5101 

3.  Professor  Hemant  Bhargava  (Code  SM/BH)  .  3 

Systems  Management  Departement 

Naval  Postgraduate  School 
Monterey,  CA  93940-5000 

4.  Professor  Gordon  H.  Bradley  (Code  OR/BZ)  .  1 

Department  of  Operations  Research 

Naval  Postgraduate  School 
Monterey,  CA  93943-5000 

5.  Professor  Carl  Jones  (Code  SM/CJ)  .  1 

Systems  Management  Departement 

Naval  Postgraduate  School 
Monterey,  CA  93943-5000 

6.  Professor  Ramayya  Krishnan  .  1 

The  Heinz  School 

Carnegie  Mellon  University 
Pittsburgh,  PA  15213 

7.  Professor  Rudolf  Muller  . .  1 

Institiit  fiir  Wirtschaftsinformatik 

Humboldt-Universitat  zu  Berlin 
Spandauer  Str.  1 
10178  Berlin,  Germany 

8.  LT  Christopher  M.  Corgnati .  2 

27  Middleton  Place 

Hertford  NC  27944 


153 


